您的位置:首页 > 理论基础 > 计算机网络

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

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

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

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

public static WebRequest Create(string);

public static WebRequest Create(uri);

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

HttpWebRequest webRequest = (HttpWebRequest) WebRequest.Create("http://www.51js.com");

因为它返回的实例类型是WebRequest而不是HttpWebRequest,因此记得要进行强制类型转换

接下来建立一个HttpWebResponse以便接收服务器发送的信息,它是调用HttpWebRequest.GetResponse来获取的:

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

如果webResponse.StatusCode的值为HttpStatusCode.OK,表示成功,那你就可以接着读取接收到的内容了:

// 获取接收到的流
Stream stream = webResponse.GetResponseStream();

// 建立一个流读取器,可以设置流编码,不设置则默认为UTF-8
System.IO.StreamReader streamReader = new StreamReader(stream, System.Text.Encoding.GetEncoding("GB2312"));

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

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

大功告成,我们已经将无忧脚本首页内容保存在content这个字符串变量中了,很简单吧?当然,根据需要还有更多设计方法可以选择,比如使用Socket,那还提供了System.Net.Sockets命名空间中的类,学.Net的朋友有事没事逛逛MSDN,肯定会有更多的收获。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: