C#实现简单的Http请求实例
本文实例讲述了c#实现简单的http请求的方法。分享给大家供大家参考。具体分析如下:
通过.net中的两个类httpwebrequest类,httpwebresponse类来实现http的请求,响应处理。
第一个小测试是请求百度首页(http://www.baidu.com)的内容,也就是要获得百度首页的html内容,
实现步骤:
1.通过webrequest类创建一个httpwebrequest的对象,该对象可以包含http请求信息。
(这里有点供大家思考:为什么要通过父类webrequest来创建这个对象,而不能new一个httpwebrequest来创建,在httpwebrequest类中的构造函数是:protected httpwebrequest(serializationinfo serializationinfo, streamingcontext streamingcontext); )
2.设置httpwebrequest对象,其实就是设置http请求报文的信息内容。
3.从httpwebrequest对象中获取httpwebresponse对象,该对象包含http响应信息。
4.从响应信息中获取响应头信息和响应主体信息。
部分实现代码如下:
创建httpwebrequest请求,设置请求报文信息
string uri = http://www.baidu.com;
httpwebrequest request = httpwebrequest.create(uri) as httpwebrequest;
request.method = "get"; //请求方法
request.protocolversion = new version(1, 1); //http/1.1版本
//add other ...
接收响应,输出响应头部信息以及主体信息
httpwebresponse response=
request.getresponse() as httpwebresponse;
//header
foreach (var item in response.headers)
{
this.txt_header.text += item.tostring()+": " +
response.getresponseheader (item.tostring())
+ system.environment.newline;
}
//如果主体信息不为空,则接收主体信息内容
if (response.contentlength <= 0)
return;
//接收响应主体信息
using(stream stream =response.getresponsestream())
{
int totallength=(int)response.contentlength;
int numbytesread=0;
byte[] bytes=new byte[totallength+1024];
//通过一个循环读取流中的数据,读取完毕,跳出循环
while( numbytesread < totallength )
{
int num=stream.read(bytes,numbytesread,1024); //每次希望读取1024字节
if( num==0 ) //说明流中数据读取完毕
break;
numbytesread+=num;
}
}
//将接收到的主体数据显示到界面
string content=encoding.utf8.getstring(bytes);
this.txt_content.text=content;
第二个小测试是请求网上的一张图片,并将图片保存到本地。
实现步骤与第一个小测试的非常类似,通过图片的url向服务器进行请求,然后接收响应,响应的主体信息内容保存为本地图片文件。一小点不同之处就在于需要将主体内容保存为文件形式,不是显示到界面上。
关键代码如下:
//...
string url="http://xx.xxx/xx.jpg"; //图片资源的url
//...
using (stream stream = response.getresponsestream())
{
//当前时间作为文件名
string filename = datetime.now.tostring("yyyymmddhhmmss")+".jpg";
using (stream fsstream = new filestream(filename, filemode.create))
{
stream.copyto(fsstream);
}
}
附:运行结果如下图:
希望本文所述对大家的c#程序设计有所帮助。