使用HttpClient和WebRequest时POST一个对象的写法

【一】步骤:

1)将对象转化为Json字符串。

2)将Json字符串编码为byte数组。

3)设置传输对象(WebRequest或者HttpClient)的ContentType是"application/json"。

4)设置传输对象的ContentLength=Byte数组的长度。

5)开始传输

6)获取JSON结果:

【二】示例代码:

【对于WebRequest而言】

static void SendByWebRequesttoApi()
        {
            WebRequest req = WebRequest.Create("http://localhost:15203/api/ApiDefault");
            var stu = new Student { ID = 1, Name = "董玮" };
            string jsonString = JsonConvert.SerializeObject(stu);
            byte[] objectContent = Encoding.UTF8.GetBytes(jsonString);
            req.ContentLength = objectContent.Length;
            req.ContentType = "application/json";
            req.Method = "POST";
            using (var stream = req.GetRequestStream())
            {
                stream.Write(objectContent, 0, objectContent.Length);
                stream.Close();
            }

            var resp = req.GetResponse();
            using (StreamReader sr = new StreamReader(resp.GetResponseStream()))
            {
                string s = sr.ReadToEnd();
                System.Console.WriteLine(s);
            }
        }

【对于HttpClient而言】

static void SendByHttpClienttoApi()
        {
            var stu = new { ID = 1, Name = "董玮" };
            using (var client = new HttpClient())
            {
                string jsonString = JsonConvert.SerializeObject(stu);
                byte[] bytes = Encoding.UTF8.GetBytes(jsonString);
                using (StreamContent sc = new StreamContent(new MemoryStream(bytes)))
                {
                    sc.Headers.ContentLength = bytes.Length;
                    sc.Headers.ContentType = new System.Net.Http.Headers.MediaTypeHeaderValue("application/json");
                    var result = client.PostAsync("http://localhost:15203/api/ApiDefault", sc).Result;
                    var objectResult = JsonConvert.DeserializeObject<Student>(result.Content.ReadAsStringAsync().Result);
                }

            }
        }

另外注意,以上是针对WebApi(WebApi默认是JSON格式数据传输)。如果是MVC的模式,那么默认是表单形式传输。因此:

 static void SendByWebRequesttoMVC()
        {
            WebRequest req = WebRequest.Create("http://localhost:15203/Default/DoGetStudent");
            var htmlFormPost = "ID=1&Name=董玮";
            byte[] objectContent = Encoding.UTF8.GetBytes(htmlFormPost);
            req.ContentLength = objectContent.Length;
            req.ContentType = "application/x-www-form-urlencoded";   //必须写!
            req.Method = "POST";
            using (var stream = req.GetRequestStream())
            {
                stream.Write(objectContent, 0, objectContent.Length);
                stream.Close();
            }

            var resp = req.GetResponse();
            using (StreamReader sr = new StreamReader(resp.GetResponseStream()))
            {
                string s = sr.ReadToEnd();
                System.Console.WriteLine(s);
            }
        }

在HttpClient中,把StreamContent改为FormUrlEncodedContent,传入一个Dictionary<string,string>对象即可:

 static void SendByHttpClienttoMVC()
        {
            using (var client = new HttpClient())
            {
                FormUrlEncodedContent fc = new FormUrlEncodedContent(new Dictionary<string, string>() { { "ID", "1" }, { "Name", "董玮" } });
                var result = client.PostAsync("http://localhost:15203/Default/DoGetStudent", fc).Result;
                System.Console.WriteLine(result.Content.ReadAsStringAsync().Result);
            }
        }

原文地址:https://www.cnblogs.com/coce/p/9721034.html

时间: 2024-07-31 11:07:06

使用HttpClient和WebRequest时POST一个对象的写法的相关文章

实现在 .net 中使用 HttpClient 下载文件时显示进度

原文:实现在 .net 中使用 HttpClient 下载文件时显示进度 在 .net framework 中,要实现下载文件并显示进度的话,最简单的做法是使用 WebClient 类.订阅 DownloadProgressChanged 事件就行了. 但是很可惜,WebClient 并不包含在 .net standard 当中.在 .net standard 中,要进行 http 网络请求,我们用得更多的是 HttpClient.另外还要注意的是,UWP 中也有一个 HttpClient,虽然

cocos2d-x 3.0 引用第三方库 及编译成apk时android mk文件写法

cocos2d-x 3.0 中,如果你需要使用CocosStudio.Extensions扩展库 等等,都需要自己手动添加. 添加步骤如下:(比如说现在我要添加libExtensions,libCocosStudio , libGUI) 1.添加附加项目 右击解决方案--->添加现有项目--->添加:项目目录\cocos2d\extensions\proj.win32\libExtensions,然后你会发现左边多了一个libExtensions扩展库 右击解决方案--->添加现有项目-

Ado访问sqlserver 端口号非1433时 连接串的写法

Ado访问sqlserver 端口号非1433时 连接串的写法 Provider=SQLOLEDB.1;Persist Security Info=False;Data Source=hostName,Port //注意用 逗号分隔主机名与端口号

httpclient访问网站时设置Accept-Encoding为gzip,deflate返回的结果为乱码的问题

近期迷恋上httpclient模拟各种网站登陆,浏览器中的开发者工具中查看请求头信息,然后照葫芦画瓢写到httpclient的请求中去,requestheader中有这么一段设置: Accept-Encoding gzip,deflate 之前模拟其他网站的时候这块并没有太在意,因为无论我在httpclient中添加上这段还是不添加,请求网站数据都没有任何影响,也不影响网站的安全检测,所以当时也就没有特别关注这个设置,直到模拟登陆58同城网站的时候第一次遇到这个问题,当添加上以上的这行请求头设置

Android浏览器:httpclient发送请求时TCP发送带有多个Segments

Android浏览器在发送HTTP(get/post)请求时,将请求首部切成多个segment.抓包如下: iPhone5没有发现此现象. ...待完善...

使用httpclient抓取时,netstat 发现很多time_wait连接

http://wiki.apache.org/HttpComponents/FrequentlyAskedConnectionManagementQuestions 1. Connections in TIME_WAIT State After running your HTTP application, you use the netstat command and detect a lot of connections in stateTIME_WAIT. Now you wonder wh

HttpClient 调用WebAPI时,传参的三种方式

public void Post() { //方法一,传json参数 var d = new { username = " ", password = " ", grant_type = "password", appcode = " ", companyid = " ", version = "1.0", }; var data = JsonConvert.SerializeObjec

Java中迭代列表中数据时几种循环写法的效率比较

Java中经常会用到迭代列表数据的情况,本文针对几种常用的写法进行效率比较.虽然网上已经有了类似的文章,但是对他们的结论并不认同. 常见的实现方法: 1.for循环: [java] view plaincopyprint? for(int i = 0; i < list.size(); i++) for(int i = 0, size = list.size(); i < size; i++) 一般人都会认为第二种写法效率高. 2.foreach: [java] view plaincopyp

【python】查找字符串时哪一种写法出结果速度更快?

现有一文本,每行一条数据,实现这行数据中有所要关键字则打出这行 import sys with open(sys.argv[1]) as alls: alls2 = [_.strip() for _ in alls] for _ in alls2: if sys.argv[2] in _: print _ 一开始我是这么写的,后来觉得既不美观,速度又慢(运行花了2.31 s),进行了改写 with open( sys.argv[1] ) as alls: results = [ _.strip(