使用HttpWebRequest以及HttpWebResponse读取Http远程文件[转]
在以前我们经常是使用XmlHttp来获取某个网页的内容,现在.Net时代已经来临,是否我们还要使用XMLHttp来获取呢?答案当然是不,因为微软已经帮我们写好了一些容易使用的类,而这些类就放在System.Net命名空间中。
这篇文章将会使用到两个类:System.Net.HttpWebRequest以及System.Net.HttpWebResponse,它们负责发送以及接收请求,我们现在就来试一下获取http://www.cnblogs.com/mugua/的首页代码,以下以代码作示例。
首先建立一个HttpWebRequest实例,我们不用使用HttpWebRequest类的构造函数,而是使用WebRequest类提供的静态方法Create,它的原型如下:
public static WebRequest Create(string); public static WebRequest Create(uri);
一般我们可以使用第一种方法,就是直接将网址传进去,如果协议为http或者https,它会返回一个HttpWebRequest实例:
HttpWebRequest webRequest = (HttpWebRequest)WebRequest.Create( "http://www.cnblogs.com/mugua/");
因为它返回的实例类型是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,肯定会有更多的收获。