网络数据请求request
关于网络数据请求的类很多,httpwebrequest,webrequest,webclient以及httpclient,具体差别在此不在赘述,在应用方面介绍webclient与httpclient则显得比较比较简单粗暴,httpwebrequest继承自webrequest,可通过参数进行请求控制。
1)基于WebClient的post/get数据请求:
get
using (var client = new WebClient())
{
client.Encoding = Encoding.GetEncoding("utf-8");
var responseString = client.DownloadString("http://www.sojson.com/open/api/weather/json.shtml?city=闵行区"); Console.WriteLine(responseString);
Console.ReadKey();
}
post
using (var client = new WebClient())
{
client.Encoding = Encoding.GetEncoding("utf-8");
var values = new NameValueCollection();
values["api_key"] = "**********";
values["api_secret"] = "**********";
values["image_url"] = "https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1508759666809&di=b3748df04c5e54d18fe52ee413f72f37&imgtype=0&src=http%3A%2F%2Fimgsrc.baidu.com%2Fimgad%2Fpic%2Fitem%2F562c11dfa9ec8a1389c45414fd03918fa1ecc06c.jpg"; var response = client.UploadValues("https://api-cn.faceplusplus.com/facepp/v3/detect", values); var responseString = Encoding.Default.GetString(response);
Console.WriteLine(responseString);
Console.ReadKey();
}
2)基于HttpWebRequest 的get/post方法
get
/// <summary>
/// get
/// </summary>
/// <param name="url">url="http:**********"+"?"+"key1=***&key2=***"</param>
/// example :http://www.sojson.com/open/api/weather/json.shtml?city=闵行区
/// <returns></returns>
public static string GetHttp(string url)
{
HttpWebRequest httpWebRequest = (HttpWebRequest)WebRequest.Create(url); httpWebRequest.ContentType = "application/json";
httpWebRequest.Method = "GET";
httpWebRequest.Timeout = ; HttpWebResponse httpWebResponse = (HttpWebResponse)httpWebRequest.GetResponse();
StreamReader streamReader = new StreamReader(httpWebResponse.GetResponseStream());
string responseContent = streamReader.ReadToEnd(); httpWebResponse.Close();
streamReader.Close(); return responseContent;
}
post
post提交数据的方式有四种,具体体现在contentType有四种方式:application/x-www-form-urlencoded,multipart/form-data,application/json以及text/xml,本文主讲前两种方法,第三种即为通过json格式发送数据,第四种通过xml格式发送。
(一)contentType=application/x-www-form-urlencoded
此种方式应用比较普遍,但是当传递参数中存在文件如图片时则需要用到multipart/form-data方式
/// <summary>
/// 采用httpwebrequest post方法请求数据
/// </summary>
/// <param name="url"></param>
/// <param name="body">body是要传递的参数,格式:api_keyi=xxxxxx&api_secret=xxxxxxx</param>
/// <param name="contentType">application/x-www-form-urlencoded</param>
/// <returns></returns>
public static string PostHttpWebRequest(string url, string body, string contentType)
{
HttpWebRequest httpWebRequest = (HttpWebRequest)WebRequest.Create(url); httpWebRequest.ContentType = contentType;
httpWebRequest.Method = "POST";
httpWebRequest.Timeout = ; byte[] btBodys = Encoding.UTF8.GetBytes(body);
httpWebRequest.ContentLength = btBodys.Length;
httpWebRequest.GetRequestStream().Write(btBodys, , btBodys.Length); HttpWebResponse httpWebResponse = (HttpWebResponse)httpWebRequest.GetResponse();
StreamReader streamReader = new StreamReader(httpWebResponse.GetResponseStream());
string responseContent = streamReader.ReadToEnd(); httpWebResponse.Close();
streamReader.Close();
httpWebRequest.Abort();
httpWebResponse.Close(); return responseContent;
}
(二)contentType=multipart/form-data
此种方式请求数据时,请求的数据流比较繁琐,需要自己来确定,即httpWebRequest.GetRequestStream().Write(btBodys, 0, btBodys.Length);中的btBodys需要自己构造,比较繁琐。其构造主体如下所示:
HTTP请求头:
....
multipart/form-data; charset=utf-8;boundary=AaB03x //boundary=AaB03x为下文请求体中用于分隔不同请求参数的文本边界请求头可以放在请求数据流中,也可以直接在contentType中定义即contentType=multipart/form-data; charset=utf-8;boundary=AaB03x
....
HTTP请求体:
--AaB03x //第一个参数边界:即在请求头中boundary文本AaB03x前加‘’--‘’
Content-Disposition: form-data; name="key1" //换行,在此加入数据的第一个参数名称
//继续换行(即空一行)
value1 //添加第一个参数对应的值
--AaB03x //第二个参数边界:即在请求头中boundary文本AaB03x前加‘’--‘’,字符串参数格式均与上同
Content-disposition: form-data; name="key2"
value2
--AaB03x //边界,此处添加图片
Content-disposition: form-data; name="key3"; filename="file" // filename表示文件名,其值与是否为真实文件名无关
Content-Type: application/octet-stream // 表示文件形式,这也是与字符串参数的不同
图片数据 // 图片数据,为二进制byte类型数据
--AaB03x-- //结束边界,为boundary文本值AaB03x前后各加加‘’--‘’
PS:
1)边界boundary的值未不会重复的字符串,大小等因素基本没影响,一般采用boundary = string.Format("{0}", Guid.NewGuid());生成,或者采用时间参数如boundary =DateTime.Now.Ticks.ToString();
代码如下
class RequestForm
{
public class PostImage //image
{
public string fullPath;
public string imageName;
public string contentType= "application/octet-stream"; public PostImage(string path)
{
fullPath = path;
imageName = Path.GetFileName(path);
}
} class PostFile //files
{ } private static readonly Encoding encoding = Encoding.UTF8; /// <summary>
/// 调用入口
/// </summary>
/// <param name="postParameter"></param>
/// <param name="url"></param>
/// <returns></returns>
public static string OnRequest(Dictionary<string,object> postParameter,string url)//主调用程序
{
string boundary = string.Format("{0}", Guid.NewGuid());
byte[] body=GetPostForm(postParameter, boundary);
string contentType = "multipart/form-data; boundary=" + boundary;
return OnWebRequest(body, url, contentType);
//return PostForm(url, contentType, body);
} private static byte[] GetPostForm(Dictionary<string, object> postParameter,string boundary)//获取请求主体
{
Stream stream = new MemoryStream();
bool isFirstPara = false; foreach (KeyValuePair<string, object> para in postParameter)
{
if (isFirstPara)
{
stream.Write(encoding.GetBytes("\r\n"), ,encoding.GetByteCount("\r\n"));
} isFirstPara = true;
//若需要添加文件信息如txt等增加else分支添加
if (para.Value is PostImage)
{
PostImage postImage = (PostImage)para.Value;
string imageStatement = string.Format("--{0}\r\nContent-Disposition: form-data; name=\"{1}\"; filename=\"{2}\"\r\nContent-Type: {3}\r\n\r\n", new object[]
{
boundary,
para.Key,
postImage.imageName??para.Key,
postImage.contentType??"application/octet-stream"
});
stream.Write(encoding.GetBytes(imageStatement), , encoding.GetByteCount(imageStatement));
byte[] imageContent = GetImageInfo(postImage.fullPath);
stream.Write(imageContent, , imageContent.Length);
}
else
{
string regularStatement = string.Format("--{0}\r\nContent-Disposition: form-data; name=\"{1}\"\r\n\r\n{2}", boundary, para.Key, para.Value);
stream.Write(encoding.GetBytes(regularStatement), , encoding.GetByteCount(regularStatement));
}
} string end = "\r\n--" + boundary + "--\r\n";
stream.Write(encoding.GetBytes(end), , encoding.GetByteCount(end));
stream.Position = 0L;
byte[] bodyArr = new byte[stream.Length];
stream.Read(bodyArr, , bodyArr.Length);
stream.Close(); return bodyArr;
} private static string OnWebRequest(byte[] postForm,string url,string contentType)//数据请求
{
HttpWebRequest request =(HttpWebRequest)WebRequest.Create(url);
//try
//{
// HttpWebRequest request = WebRequest.Create(url) as HttpWebRequest;
//}
//catch(WebException ex)
//{
// return ex.Message;
//} if (request == null) return "Failed to connect url";
request.Method = "POST";
request.Timeout =;
request.ReadWriteTimeout =;
request.ContentType = contentType;
request.ContentLength = (long)postForm.Length; try
{
using (Stream requestStream = request.GetRequestStream())
{
int bufferSize = ;
int position = ;
while (position < postForm.Length)
{
bufferSize = Math.Min(bufferSize, postForm.Length - position); byte[] data = new byte[bufferSize];
Array.Copy(postForm, position, data, , bufferSize);
requestStream.Write(data, , data.Length);
position += data.Length;
}
//requestStream.Write(formData, 0, formData.Length);
requestStream.Close();
}
}
catch (Exception ex)
{
return ex.Message;
} HttpWebResponse result; try
{
result = (HttpWebResponse)(request.GetResponse());
}
catch (Exception ex)
{
return ex.Message;
} StreamReader streamReader = new StreamReader(result.GetResponseStream());
return streamReader.ReadToEnd();
} private static byte[] GetImageInfo(string path)//通过路径获取图片信息
{
Bitmap bmp = new Bitmap(path);
byte[] imageInfo; using (Stream stream = new MemoryStream())
{
bmp.Save(stream,ImageFormat.Jpeg);
byte[] arr = new byte[stream.Length];
stream.Position = ;
stream.Read(arr, , (int)stream.Length);
stream.Close();
imageInfo = arr;
} return imageInfo;
} }
调用代码:
static void Main(string[] args)
{
string imagePath = @"D:\test\image\1.jpg";
string url = "https://api-cn.faceplusplus.com/facepp/v3/detect";
RequestForm.PostImage postImage = new RequestForm.PostImage(imagePath); Dictionary<string, object> postParameter = new Dictionary<string, object>();
postParameter.Add("api_key", "*************************");
postParameter.Add("api_secret", "**************************");
postParameter.Add("image_file", postImage);
//postParameter.Add("image_url", "http://imgtu.5011.net/uploads/content/20170328/7150651490664042.jpg"); string result = RequestForm.OnRequest(postParameter, url);
Console.WriteLine(result);
Console.ReadKey();
}
调用时参数为请求的url以及Dictionary<string, object> 类型的主体参数,传入图片时只需要一个参数调用时的key(上述代码为"image_file")和包含图片路径的对象postImage,如果传入参数还需要其他文件如Txt格式等的文件时,只需要通过filestream读取出来即可
网络数据请求request的更多相关文章
- iOS - NetRequest 网络数据请求
1.网络请求 1.1 网络通讯三要素 1.IP 地址(主机名): 网络中设备的唯一标示.不易记忆,可以用主机名(域名). 1) IP V4: 0~255.0~255.0~255.0~255 ,共有 2 ...
- swift网络数据请求方法
搭建一个apache服务器,用php编写一个返回给客户端请求数据的脚本 <?php // header("Content-type:text/html;charset=utf-8&qu ...
- react native之使用 Fetch进行网络数据请求
这是一个单独的页面,可以从其他地方跳转过来. 输入语言关键字,从github检索相关数据 import React, {Component} from 'react'; import { StyleS ...
- Android利用Fiddler进行网络数据抓包,手机抓包工具汇总
Fiddler抓包工具 Fiddler抓包工具很好用的,它可以干嘛用呢,举个简单例子,当你浏览网页时,网页中有段视频非常好,但网站又不提供下载,用迅雷下载你又找不到下载地址,这个时候,Fiddler抓 ...
- iOS中GET 和 POST 数据请求
iOS中GET 和 POST 网络数据请求 同步请求和异步请求的差别: 1.同步请求,有主线程完成网路请求任务,在数据没有请求之前,用户的所有的交互事件应用都无法处理,会造成一种卡顿现象,影响用户体验 ...
- Android利用Fiddler进行网络数据抓包,手机抓包工具汇总,使用mono运行filddler
Fiddler抓包工具 Fiddler抓包工具很好用的,它可以干嘛用呢,举个简单例子,当你浏览网页时,网页中有段视频非常好,但网站又不提供下载,用迅雷下载你又找不到下载地址,这个时候,Fiddler抓 ...
- Android利用tcpdump和wireshark抓取网络数据包
Android利用tcpdump和wireshark抓取网络数据包 主要介绍如何利用tcpdump抓取andorid手机上网络数据请求,利用Wireshark可以清晰的查看到网络请求的各个过程包括三次 ...
- Android之MVP模式实现登录和网络数据加载
MVP简介 相信大家对 MVC 都是比较熟悉了:M-Model-模型.V-View-视图.C-Controller-控制器,MVP作为MVC的演化版本,也是作为用户界面(用户层)的实现模式,那么类似的 ...
- Android - 使用Volley请求网络数据
Android - 使用Volley请求网络数据 Android L : Android Studio 14 个人使用volley的小记,简述使用方法,不涉及volley源码 准备工作 导入Volle ...
随机推荐
- python3在word文档中查找多行文字是否存在
工作中碰到这样一个情况:有多个关键词存在文本文档txt中,想查找下在某个较大的word文档中,这些关键词是否都含有,没有关键词的显示出来. 因为关键词比较多,并且这个工作还是经常会有的,这个情况我试着 ...
- java字符串,数组,集合框架重点
1.字符串的字面量是否自动生成一个字符串的变量? String str1 = “abc”; Sring str2 = new String (“abc”); 对于str1:Jvm在遇到双 ...
- .Net Core 商城微服务项目系列(二):使用Ocelot + Consul构建具备服务注册和发现功能的网关
1.服务注册 在上一篇的鉴权和登录服务中分别通过NuGet引用Consul这个包,同时新增AppBuilderExtensions类: public static class AppBuilderEx ...
- 关于Python json解析过程遇到的TypeError: expected string or buffer
关于Python json解析过程遇到的问题:(爬取天气json数据所遇到的问题http://tianqi.2345.com/) part.1 url——http://tianqi.2345.com/ ...
- 把功能强大的Spring EL表达式应用在.net平台
Spring EL 表达式是什么? Spring3中引入了Spring表达式语言—SpringEL,SpEL是一种强大,简洁的装配Bean的方式,他可以通过运行期间执行的表达式将值装配到我们的属性或构 ...
- LeetCode正则表达式匹配
题目描述 给你一个字符串 s 和一个字符规律 p,请你来实现一个支持 '.' 和 '*' 的正则表达式匹配. '.' 匹配任意单个字符 '*' 匹配零个或多个前面的那一个元素 所谓匹配,是要涵盖 整个 ...
- python编程基础之二十三
集合:和数学里面完全一样的,不允许有重复元素,如果添加重复元素,就会被过滤,可以进行交并差的运算 集合是可变对象 本质:无需且无重复的数据结构 创建集合 s1 = set() 括号里面可以放可迭代 ...
- SQL SERVER数据库,按年、月、日、时、分、秒计算两个时间字段之间的间隔时间样例
使用DATEDIFF(取值,时间字段1,时间字段2) 举例: SELECT DATEDIFF(YEAR,DRYSJ,DCYSJ),* FROM YXHIS2019..TBZYBR2019 --SQL ...
- mac 下修改 jenkins 端口以及Jenkins的启动、关闭与更新
安装包安装的Jenkins修改默认端口的方法: 先关闭jenkins ; 命令行下修改端口:sudo defaults write /Library/Preferences/org.jenkins-c ...
- VBS定时关闭软件
用TXT写以下代码另存为VBS格式,代码如下:doset bag=getobject("winmgmts:\\.\root\cimv2")set pipe=bag.execquer ...