c# .net core 下的网络请求
本文章是在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">网络基址("http://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 = ; 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">网络基址("http://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 = ; 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 == )
- {
- req.ContentType = "application/json;charset=utf-8";
- }
- else if (type == )
- {
- 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 = ;
- byte[] postData = encoding.GetBytes(data);
- Stream reqStream = req.GetRequestStreamAsync().Result;
- reqStream.Write(postData, , 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 = ; 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 = ; 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 = ; 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 = ; 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# .net core 下的网络请求的更多相关文章
- [Asp.net core]使用Polly网络请求异常重试
摘要 在网络传输过程中,不能保证所有的请求都能正确的被服务端接受或者处理,那么进行简单的重试可以进行简单的补救.比如现在大部分支付功能,在支付成功之后,需要回调我们网站的接口,并且要求我们的接口给一个 ...
- .Net Core下发送WebRequest请求的两种方式
1.使用RestSharp.NetCore 2.使用WebApi请求方式
- Cocoa Touch(五):网络请求 NSURLSession/AFNetworking, GCD, NSURLResquest
NSURLRequest 网络请求的关键的就是NSURLRequest类,它的实例表示了请求报文实体以及请求的缓存策略等等,各种网络框架的最终目标都是把这个对象编译成为请求报文发送出去.下面用一个实例 ...
- kotlin for android----------MVP模式下(OKHttp和 Retrofit+RxJava)网络请求的两种实现方式
今天要说的干货是:以Kotlin,在MVP模式下(OKHttp和 Retrofit+RxJava)网络请求两种实现方式的一个小案例,希望对大家有所帮助,效果图: Retrofit是Square公司开发 ...
- 线程安全-一个VC下多个网络请求
一.线程安全变量控制显示隐藏loading框 问题描写叙述: 同一页面有两个异步网络请求,第一个请求開始,loading旋转.第二个请求開始loading旋转.第一个结束,loading停止旋转,但是 ...
- # Volley源码解析(二) 没有缓存的情况下直接走网络请求源码分析#
Volley源码解析(二) 没有缓存的情况下直接走网络请求源码分析 Volley源码一共40多个类和接口.除去一些工具类的实现,核心代码只有20多个类.所以相对来说分析起来没有那么吃力.但是要想分析透 ...
- android网络编程注意事项之一:移动网络下,防止网络超时甚至连接不上,解决办法--为网络请求设置代理
Android应用程序访问互联网资源时,在Wifi的情况下处理网络连接按照上文所讲述的方法步骤即可顺利实现:但如果当前Android设备的联网方式是通过移动运营商的网络服务为中转,间接访问的互联网资源 ...
- Angular2入门系列教程7-HTTP(一)-使用Angular2自带的http进行网络请求
上一篇:Angular2入门系列教程6-路由(二)-使用多层级路由并在在路由中传递复杂参数 感觉这篇不是很好写,因为涉及到网络请求,如果采用真实的网络请求,这个例子大家拿到手估计还要自己写一个web ...
- AndroidInject项目使用动态代理增加对网络请求的支持
以下内容为原创,欢迎转载,转载请注明 来自天天博客:http://www.cnblogs.com/tiantianbyconan/p/3540427.html AndroidInject项目是我写的一 ...
随机推荐
- 【转】HTML5 本地存储五种方案
1.LocalStorage LocalStorage就是Key-Value的简单键值对存储结构,Web Storage除了localStorage的持久性存储外,还 有针对本次回话的sessionS ...
- 老李分享:https协议
老李分享:https协议 最近我们看到很多站点使用 HTTPS 协议提供网页服务.通常情况下我们都是在一些包含机密信息的站点像银行看到 HTTPS 协议. 如果你访问 google,查看一下地址栏 ...
- POPTEST学员就业面试题目!!!!!
POPTEST学员就业面试题目!!!!! poptest是国内唯一一家培养测试开发工程师的培训机构,以学员能胜任自动化测试,性能测试,测试工具开发等工作为目标.(欢迎大家咨询软件测试工程师就业培训 ...
- GEF开发eclipse插件,多页编辑器实现delete功能
基于GEF开发,多页签编辑器实现 有两种方案: 方案一 继承FormEditor或MultiPageEditorPart,在其中嵌入自定义的继承自GraphicalEditor的子类的编辑器(作为一个 ...
- 职责链模式(Chain of Responsibility)的Java实现
职责链模式(Chain of Responsibility):使多个对象都有机会处理请求,从而避免请求的发送者和接收者之间的耦合关系.将这些对象连成一条链,并沿着这条链传递该请求,直到有一个对象处理它 ...
- Twitter数据抓取的方法(一)
Scraping Tweets Directly from Twitters Search Page – Part 1 Published January 8, 2015 EDIT – Since I ...
- ios UICollectionView简单说明
原谅我记不住写下来好了 UICollectionViewFlowLayout 流式自动布局 继承于UICollectionViewLayout 初始化:[[UICollectionViewFlowLa ...
- iOS关于JSONKit解析Unicode字符内容出错,问题出在\u0000
JSONKit虽然很强大,但是一些特殊的Unicode,比如\u0000是无法解析的. 在github上作者解释了这个问题,说这个是内容提供的错误,不符合标准的内容,所以他不认为这个是自己的错误,这个 ...
- mysql常用技能分享
一,MySQL查询的五种子句: 1,where(条件查询),常用的运算符: ①比较运算符 > , < , = , != , >= , <= , in( ) , between ...
- JSON对象、JSON字符串的相互转换
JSON对象.JSON字符串的相互转换 json的格式: 第一种方式: 单一的json字符串,转换成json对象时,需要 eval('(' + json + ')');这样的格式,中间需要加括号 va ...