使用HttpWebRequest以及HttpWebResponse读取Http远程文件

使用HttpWebRequest以及HttpWebResponse读取Http远程文件

jackyhwei 发布于 2010-08-15 21:24 点击: 1054次 
来自:博客园
在以前我们经常是使用XmlHttp来获取某个网页的内容,现在.Net时代已经来临,是否我们还要使用XMLHttp来获取呢?答案当然是不,因为微软已经帮我们写好了一些容易使用的类,而这些类就放在System.Net命名空间中。
TAG: webservice  XMLHTTP  

在以前我们经常是使用XmlHttp来获取某个网页的内容,现在.Net时代已经来临,是否我们还要使用XMLHttp来获取呢?答案当然是不,因为微软已经帮我们写好了一些容易使用的类,而这些类就放在System.Net命名空间中。

这篇文章将会使用到两个类:System.Net.HttpWebRequest以及System.Net.HttpWebResponse,它们负责发送以及接收请求,我们现在就来试一下获取http://www.rosoo.net的首页代码,以下以代码作示例。

首先建立一个HttpWebRequest实例,我们不用使用HttpWebRequest类的构造函数,而是使用WebRequest类提供的静态方法Create,它的原型如下:

public static WebRequest Create(string);
public static WebRequest Create(uri);

一般我们可以使用第一种方法,就是直接将网址传进去,如果协议为http或者https,它会返回一个HttpWebRequest实例:

HttpWebRequest webRequest = (HttpWebRequest)WebRequest.Create( "http://www.rosoo.net");

因为它返回的实例类型是WebRequest而不是HttpWebRequest,因此记得要进行强制类型转换.
接下来建立一个HttpWebResponse以便接收服务器发送的信息,它是调用HttpWebRequest.GetResponse来获取的:

HttpWebResponse webResponse = (HttpWebResponse)webRequest.GetResponse();

如果webResponse.StatusCode的值为HttpStatusCode.OK,表示成功,那你就可以接着读取接收到的内容了:
Stream stream = webResponse.GetResponseStream(); // 获取接收到的流

System.IO.StreamReader streamReader = new StreamReader(stream, System.Text.Encoding.GetEncoding("GB2312"));

// 建立一个流读取器,可以设置流编码,不设置则默认为UTF-8

string content = streamReader.ReadToEnd();// 读取流字符串内容

streamReader.Close();// 关闭相关对象
webResponse.Close();

大功告成,我们已经将无忧脚本首页内容保存在content这个字符串变量中了,很简单吧?当然,根据需要还有更多设计方法可以选择,比如使用Socket,那还提供了System.Net.Sockets命名空间中的类,学.Net的朋友有事没事逛逛MSDN,肯定会有更多的收获。

(mugua)
 
转载请注明:文章转载自:罗索实验室 [http://www.rosoo.net/a/201008/9976.html]
posted on 2014-08-12 08:56  尼欧  阅读(2376)  评论(0编辑  收藏  举报