详解c# .net core 下的网络请求
 更新时间:2017年05月23日 10:33:49   作者:SZMD.ls.nct  

本篇文章主要介绍了详解c# .net core 下的网络请求,大致介绍下在.net core 下如何进行http请求,主要仍然是GET和POST方法,有兴趣的可以了解下

本文章是在VS2017的环境下,.net core 1.1版本以上。
在这期间,由于.net core 并不基于IIS,我们的过去的网络请求代码在.net core框架下,有可能会出现不兼容,报错的现象。这里大致介绍下在.net core 下如何进行http请求,主要仍然是GET和POST方法,有错误的地方,欢迎指正!
先来说POST,POST我实现了三种方法,前两种基于的原理是完全一致的,后面的有些小小的差异,但他们的本质都是http请求,本质上是无区别的,只是实现方法有所不同。
废话不多说,上代码:
POST异步方法:

/// <summary>
/// 异步请求post(键值对形式,可等待的)
/// </summary>
/// <param name=”uri”>网络基址(“localhost:59315″)</param>
/// <param name=”url”>网络的地址(“/api/UMeng”)</param>
/// <param name=”formData”>键值对List<KeyValuePair<string, string>> formData = new List<KeyValuePair<string, string>>();formData.Add(new KeyValuePair<string, string>(“userid”, “29122”));formData.Add(new KeyValuePair<string, string>(“umengids”, “29122”));</param>
/// <param name=”charset”>编码格式</param>
/// <param name=”mediaType”>头媒体类型</param>
/// <returns></returns>
public async Task<string> HttpPostAsync(string uri, string url, List<KeyValuePair<string, string>> formData = null, string charset = “UTF-8”, string mediaType = “application/x-www-form-urlencoded”)
{

string tokenUri = url;
var client = new HttpClient();
client.BaseAddress = new Uri(uri);
HttpContent content = new FormUrlEncodedContent(formData);
content.Headers.ContentType = new MediaTypeHeaderValue(mediaType);
content.Headers.ContentType.CharSet = charset;
for (int i = 0; i < formData.Count; i++)
{
content.Headers.Add(formData[i].Key, formData[i].Value);
}

HttpResponseMessage resp = await client.PostAsync(tokenUri, content);
resp.EnsureSuccessStatusCode();
string token = await resp.Content.ReadAsStringAsync();
return token;
}

POST同步方法:

/// <summary>
/// 同步请求post(键值对形式)
/// </summary>
/// <param name=”uri”>网络基址(“localhost:59315″)</param>
/// <param name=”url”>网络的地址(“/api/UMeng”)</param>
/// <param name=”formData”>键值对List<KeyValuePair<string, string>> formData = new List<KeyValuePair<string, string>>();formData.Add(new KeyValuePair<string, string>(“userid”, “29122”));formData.Add(new KeyValuePair<string, string>(“umengids”, “29122”));</param>
/// <param name=”charset”>编码格式</param>
/// <param name=”mediaType”>头媒体类型</param>
/// <returns></returns>
public string HttpPost(string uri, string url, List<KeyValuePair<string, string>> formData = null, string charset = “UTF-8”, string mediaType = “application/x-www-form-urlencoded”)
{
string tokenUri = url;
var client = new HttpClient();
client.BaseAddress = new Uri(uri);
HttpContent content = new FormUrlEncodedContent(formData);
content.Headers.ContentType = new MediaTypeHeaderValue(mediaType);
content.Headers.ContentType.CharSet = charset;
for (int i = 0; i < formData.Count; i++)
{
content.Headers.Add(formData[i].Key, formData[i].Value);
}

var res = client.PostAsync(tokenUri, content);
res.Wait();
HttpResponseMessage resp = res.Result;

var res2 = resp.Content.ReadAsStringAsync();
res2.Wait();

string token = res2.Result;
return token;
}

遗憾的是,同步方法也是基于异步实现的,个人认为这样做会加大系统开销。如果各位有其他的高效实现,请不吝赐教!
接下来是通过流的方式进行POST:

public string Post(string url, string data, Encoding encoding, int type)
{
try
{
HttpWebRequest req = WebRequest.CreateHttp(new Uri(url));
if (type == 1)
{
req.ContentType = “application/json;charset=utf-8”;
}
else if (type == 2)
{
req.ContentType = “application/xml;charset=utf-8”;
}
else
{
req.ContentType = “application/x-www-form-urlencoded;charset=utf-8”;
}

req.Method = “POST”;
//req.Accept = “text/xml,text/javascript”;
req.ContinueTimeout = 60000;

byte[] postData = encoding.GetBytes(data);
Stream reqStream = req.GetRequestStreamAsync().Result;
reqStream.Write(postData, 0, postData.Length);
reqStream.Dispose();

var rsp = (HttpWebResponse)req.GetResponseAsync().Result;
var result = GetResponseAsString(rsp, encoding);
return result;

}
catch (Exception ex)
{
throw;
}
}

private string GetResponseAsString(HttpWebResponse rsp, Encoding encoding)
{
Stream stream = null;
StreamReader reader = null;

try
{
// 以字符流的方式读取HTTP响应
stream = rsp.GetResponseStream();
reader = new StreamReader(stream, encoding);
return reader.ReadToEnd();
}
finally
{
// 释放资源
if (reader != null) reader.Dispose();
if (stream != null) stream.Dispose();
if (rsp != null) rsp.Dispose();
}
}

这种方式的POST还是将数据写入到流里面,进行POST,之所以写前两个key-value的形式,是为了符合java或者oc的风格,在c#书写的webapi中,由于接收形式是{=value}而不是{key=value}(由webapi的性质决定),后续我会说如何在webapi中接收(key-value)的形式,适当避免.net后台人员与android和ios的矛盾,从而达到社会主义民主社会的长治久安。
接下来是get,同样同步异步都是由异步实现的,还请各位看官轻喷。
GET:

/// <summary>
/// 异步请求get(UTF-8)
/// </summary>
/// <param name=”url”>链接地址</param>
/// <param name=”formData”>写在header中的内容</param>
/// <returns></returns>
public static async Task<string> HttpGetAsync(string url, List<KeyValuePair<string, string>> formData = null)
{
HttpClient httpClient = new HttpClient();
HttpContent content = new FormUrlEncodedContent(formData);
if (formData != null)
{
content.Headers.ContentType = new MediaTypeHeaderValue(“application/x-www-form-urlencoded”);
content.Headers.ContentType.CharSet = “UTF-8″;
for (int i = 0; i < formData.Count; i++)
{
content.Headers.Add(formData[i].Key, formData[i].Value);
}
}
var request = new HttpRequestMessage()
{
RequestUri = new Uri(url),
Method = HttpMethod.Get,
};
for (int i = 0; i < formData.Count; i++)
{
request.Headers.Add(formData[i].Key, formData[i].Value);
}
var resp = await httpClient.SendAsync(request);
resp.EnsureSuccessStatusCode();
string token = await resp.Content.ReadAsStringAsync();

return token;
}

/// <summary>
/// 同步get请求
/// </summary>
/// <param name=”url”>链接地址</param>
/// <param name=”formData”>写在header中的键值对</param>
/// <returns></returns>
public string HttpGet(string url, List<KeyValuePair<string, string>> formData = null)
{
HttpClient httpClient = new HttpClient();
HttpContent content = new FormUrlEncodedContent(formData);
if (formData != null)
{
content.Headers.ContentType = new MediaTypeHeaderValue(“application/x-www-form-urlencoded”);
content.Headers.ContentType.CharSet = “UTF-8”;
for (int i = 0; i < formData.Count; i++)
{
content.Headers.Add(formData[i].Key, formData[i].Value);
}
}
var request = new HttpRequestMessage()
{
RequestUri = new Uri(url),
Method = HttpMethod.Get,
};
for (int i = 0; i < formData.Count; i++)
{
request.Headers.Add(formData[i].Key, formData[i].Value);
}
var res = httpClient.SendAsync(request);
res.Wait();
var resp = res.Result;
Task<string> temp = resp.Content.ReadAsStringAsync();
temp.Wait();
return temp.Result;
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持华域联盟。

您可能感兴趣的文章:C#贪吃蛇游戏实现分析C#正则表达式匹配与替换字符串功能示例JS和C#实现的两个正则替换功能示例分析C#删除UL LI中指定标签里文字的方法C#利用ReportViewer生成报表C#动态创建button按钮的方法实例详解

.net
core
网络请求

相关文章
asp.net程序在调式和发布之间图片路径问题的解决方法图片显示的时候,在VS调式时候,地址中有个虚拟文件名,发布后则没有了.所以会有图片显示叉叉的情况.

2009-12-12
ASP.NET 2005 Treeview终极解决方案ASP.NET 2005 Treeview终极解决方案… 2006-09-09
开启SQLSERVER数据库缓存依赖优化网站性能 2010-04-04
asp.net 虚方法、抽象方法、接口疑问asp.net 虚方法、抽象方法、接口疑问等说明。 2009-06-06
ASP.NET简化编辑界面解决思路及实现代码(2)这篇与前一篇改进部分,也许大家会留意到动画演示,主要是GridVeiw的更新与删除会在每row都有。因此Insus.NET把它抽取出来,放在GridView外,感兴趣的朋友可以了解下啊,希望本文对你有所帮助 2013-01-01
详解免费开源的DotNet任务调度组件Quartz.NET(.NET组件介绍之五本篇文章主要介绍免费开源的DotNet任务调度组件Quartz.NET(.NET组件介绍之五),具有一定参考价值,有兴趣的可以了解一下。
2016-12-12
xUnit 编写 ASP.NET Core 单元测试的方法这篇文章主要介绍了xUnit 编写 ASP.NET Core 单元测试的方法,文中代码非常详细,帮助大家更好的参考和学习,感兴趣的朋友可以了解下 2020-06-06
asp.net MVC利用自定义ModelBinder过滤关键字的方法(附demo源码下这篇文章主要介绍了MVC利用自定义ModelBinder过滤关键字的方法,结合实例形式详细分析了自定义ModelBinder过滤关键字的原理与具体实现技巧,需要的朋友可以参考下 2016-03-03
DiscuzNT 论坛与主站的同步登录与退出首先我先说明一下,我参考了这篇文章:nt.discuz.net/showtopic-49836.html,在这篇文章启发下简单化。 我装的是2.5Beta版 2009-03-03
asp.net部署到IIS常见问题的解决方法这篇文章主要为大家详细介绍了asp.net部署到IIS常见问题的解决方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 2017-12-12

最新评论

声明:本站(华域联盟www.cnhackhy.com)所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。