ASP.NET MVC (五、HttpClient接口解析)

ASP.NET MVC (五、HttpClient接口解析)前言:MVC对于已经跨域的接口进行解析是个比较容易的事情。况且在第四章节的时候已经通过Ajax进行了页面的解析测试,效果也比较明显。所以本章节从容应对。这个世界上只有一种真正的英雄主义:认清生活的真相,并且仍然热爱它。难道向上攀爬的那条路,不是比站在顶峰更让人心潮澎湃吗?1、MVC项目创建在解决方案上点击【鼠标右键】,依次选择【添加】【新建项目】选择【ASP.NETWeb应用程序(.NETFramework)】项目,点击【下一步】输入项目名称,这里是【M…

大家好,又见面了,我是你们的朋友全栈君。

目录

前言:

1、MVC项目创建

 2、【GET】请求的API解析

 3、【Post】请求【API】解析


前言:

MVC对于已经跨域的接口进行解析是个比较容易的事情。况且在第四章节的时候已经通过Ajax进行了页面的解析测试,效果也比较明显。所以本章节从容应对。

ASP.NET MVC (五、HttpClient接口解析)

这个世界上只有一种真正的英雄主义:

认清生活的真相,并且仍然热爱它。难道向上攀爬的那条路,不是比站在顶峰更让人心潮澎湃吗?

1、MVC项目创建

在解决方案上点击【鼠标右键】,依次选择【添加】【新建项目】

ASP.NET MVC (五、HttpClient接口解析) 选择【ASP.NET Web应用程序(.NET Framework)】项目,点击【下一步】

ASP.NET MVC (五、HttpClient接口解析)

 输入项目名称,这里是【MVC】ASP.NET MVC (五、HttpClient接口解析)

 选择【MVC】项目,并取消【为HTTPS配置】,点击【创建】

ASP.NET MVC (五、HttpClient接口解析)

 完成创建:

ASP.NET MVC (五、HttpClient接口解析)

 2、【GET】请求的API解析

创建返回对象

[Serializable]
public class ResultType
{
    public int code { get; set; }

    public string message { get; set; }

    public object result { get; set; }
}

ASP.NET MVC (五、HttpClient接口解析)

 编写解析过程(HomeController.cs):

//客户端请求
HttpClient http = new HttpClient();
//请求地址
string url = "http://localhost:5833/api/Test/GetInfo";
//异步请求
Task<string> task = http.GetStringAsync(url);
//获取数据解析,并发送至前台
ViewBag.ResultTyle = JsonConvert.DeserializeObject<ResultType>(task.Result);
return View();

ASP.NET MVC (五、HttpClient接口解析)

前台编码:

ASP.NET MVC (五、HttpClient接口解析)

 清空当前【Index】视图所有内容【Ctrl+A+Delete】

ASP.NET MVC (五、HttpClient接口解析)

 输入以下编码:

@ViewBag.ResultTyle.code
<hr/>
@ViewBag.ResultTyle.message
<hr/>
@ViewBag.ResultTyle.result

 启动测试(需要api与mvc均运行)

ASP.NET MVC (五、HttpClient接口解析)

先行启动【demo】的【api】项目后,将 【MVC】设为启动项。

ASP.NET MVC (五、HttpClient接口解析)

解析成功:

ASP.NET MVC (五、HttpClient接口解析)

 3、【Post】请求【API】解析

 编写解析过程(HomeController.cs):

//客户端请求
HttpClient http = new HttpClient();
var str = "";//请求数据。这里为空
HttpContent content = new StringContent(str);
//请求地址
string url = "http://localhost:5833/api/Test/GetPostInfo";
Task<HttpResponseMessage> postTask = http.PostAsync(url,content);
HttpResponseMessage result = postTask.Result;//拿到网络请求结果
result.EnsureSuccessStatusCode();//抛出异常
Task<string> task = result.Content.ReadAsStringAsync();//异步读取数据
//发送值前台
ViewBag.ResultTyle = JsonConvert.DeserializeObject<ResultType>(task.Result);

编码位置:

ASP.NET MVC (五、HttpClient接口解析)

 请求效果:

ASP.NET MVC (五、HttpClient接口解析)

 如果需要传递数据请进行序列化操作:

//例如:
//序列化
user user = new user();
user.userName= "admin";
user.password = "123456";
var str = JsonConvert.SerializeObject(user);

post传参案例

注:【传参无非就是以【?&】字符串拼接后执行】

[HttpPost]
public void UpdateInfo(string id,string nickName,string introduce) {
    //请求地址
    string url = string.Format("http://localhost:5534/api/Test/UpdateById?id={0}&nickName={1}&introduce={2}", id, nickName, introduce);
    //发送值前台
    Success success = RequestPost(url);
    //根据请求返回判断结果
    if (success.code == 200)
    {
        Response.Write("<script>alert('" + success.message + "');window.location.href='Index'</script>");
    }
    else
    {
        Response.Write("<script>alert('" + success.message + "');window.location.href='UpdatePage'</script>");
    }
}


/// <summary>
/// Post
/// </summary>
/// <param name="url"></param>
/// <returns></returns>
public Success RequestPost(string url) {
    //客户端请求
    HttpClient http = new HttpClient();
    var str = "";//请求数据。这里为空
    HttpContent content = new StringContent(str);
    //请求地址
    Task<HttpResponseMessage> postTask = http.PostAsync(url, content);
    HttpResponseMessage result = postTask.Result;//拿到网络请求结果
    result.EnsureSuccessStatusCode();//抛出异常
    Task<string> task = result.Content.ReadAsStringAsync();//异步读取数据
    //发送值前台
    return JsonConvert.DeserializeObject<Success>(task.Result);
}

希望能对大家有所帮助。 

 第五章【五、ASP.NET MVC (五、HttpClient接口解析)】完结。

【一、控制器与视图:https://laoshifu.blog.csdn.net/article/details/120126288

【二、数据传递:https://laoshifu.blog.csdn.net/article/details/120127320

【三、表单与文件上传:https://laoshifu.blog.csdn.net/article/details/120130566

【四、ASP.NET Web API应用程序与跨域操作:https://laoshifu.blog.csdn.net/article/details/120160728

【五、HttpClient接口解析:https://laoshifu.blog.csdn.net/article/details/120332379

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/162930.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)
blank

相关推荐

  • 数据结构与算法(十六):平衡二叉树

    数据结构与算法(十六):平衡二叉树一、什么是平衡二叉树1.概述平衡二叉树(AVL树)是一种带有平衡条件的二叉搜索树。它的特性如下:AVL树的左右两个子树的高度差的绝对值不超过1AVL树的左右两个子树都是一棵平衡二叉树举个例子

  • jrtplib介绍[通俗易懂]

    jrtplib介绍[通俗易懂]程序流程发送:获得接收端的IP地址和端口号创建RTP会话指定RTP数据接收端设置RTP会话默认参数发送流媒体数据接收:获得用户指定的端口号创建RTP会话设置接收模式接受RTP数据检索RTP数据源获取RTP数据报删除RTP数据报1.初始化I、在使用JRTPLIB进行实时流媒体数据传输之前,首先应该生成R…

  • struts2 拦截器_struts2自定义拦截器

    struts2 拦截器_struts2自定义拦截器拦截器(interceptor)是Struts2最强大的特性之一,也可以说是struts2的核心,拦截器可以让你在Action和result被执行之前或之后进行一些处理。同时,拦截器也可以让你将通用的代码模块化并作为可重用的类。Struts2中的很多特性都是由拦截器来完成的。拦截是AOP的一种实现策略。拦截器是动态拦截Action调用的对象。它提供了一种机制可以使开发者可以定义在一个action…

  • js正则使用变量_正则表达式中可以拼接变量吗

    js正则使用变量_正则表达式中可以拼接变量吗javascript正则变量evalRegExp

  • 一篇读懂:Android手机如何通过USB接口与外设通信(附原理分析及方案选型)

    一篇读懂:Android手机如何通过USB接口与外设通信(附原理分析及方案选型)0背景1.手机USB接口通信特点-1.1使用方便-1.2通用性强-1.3速度快-1.4可采用总线供电2.手机USB接口通信原理-2.1常见手机USB接口-2.2通信过程-2.3体系架构2.4软件层次3.手机USB接口与外设通信方案-3.1USB(手机)USB(外设)-3.1.1USBHost简述

  • cad怎样生成轮廓线(图样中可见轮廓线用什么线)

    一般在做影像处理时,为提升效率,常会将影像转为二值影像后再进行处理。在EmguCV内有许多找轮廓线的方法,但是随着版本更新,不同版本的函数不见得会一样,每次都要重新查询实在很麻烦,那不如把他们记下来。版本概要:EmguCV版本:3.2.0.2682编译器版本:VisualStudio2017Community方案平台:x64(许多导致程式无法执行的原因是因为没有改执

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号