教程集 www.jiaochengji.com
教程集 >  脚本编程  >  Asp.net  >  正文 C# Winform获取网页源文件的实现方法

C# Winform获取网页源文件的实现方法

发布时间:2016-04-25   编辑:jiaochengji.com
本文介绍下,在C#的winform开发中,获取网页源文件的方法,有需要的朋友,可以参考下。

在C# Winform 应用程序中,获取某网页的源文件的方法。

代码如下:
 

复制代码 代码示例:

//引入名称空间
using System.IO;
using System.Net;

WebClient MyWebClient = new WebClient();

MyWebClient.Credentials = CredentialCache.DefaultCredentials;//获取或设置用于向Internet资源的请求进行身份验证的网络凭据
Byte[] pageData = MyWebClient.DownloadData("http://www.jbxue.com");
//string pageHtml = Encoding.Default.GetString(pageData);
FileStream file = new FileStream("C:\\test.html", FileMode.Create);
file.Write(pageData, 0, pageData.Length);

附,c# 获取网页源码的代码举例。

C# 获取指定网页HTML原代码可使用:WebClient WebRequest HttpWebRequest 三种方式。

当然也可使用webBrowse,有兴趣的朋友,可以自己研究下。

1,WebClient方式
 

复制代码 代码示例:
private string GetWebClient(string url)
{
    string strHTML = "";
    WebClient myWebClient = new WebClient();
    Stream myStream = myWebClient.OpenRead(url);
    StreamReader sr = new StreamReader(myStream, System.Text.Encoding.GetEncoding("utf-8"));
    strHTML = sr.ReadToEnd();
    myStream.Close();
    return strHTML;
}

2,WebRequest方式
 

复制代码 代码示例:
private string GetWebRequest(string url)
{
    Uri uri = new Uri(url);
    WebRequest myReq = WebRequest.Create(uri);
    WebResponse result = myReq.GetResponse();
    Stream receviceStream = result.GetResponseStream();
    StreamReader readerOfStream = new StreamReader(receviceStream, System.Text.Encoding.GetEncoding("utf-8"));
    string strHTML = readerOfStream.ReadToEnd();
    readerOfStream.Close();
    receviceStream.Close();
    result.Close();
    return strHTML;
}

3,HttpWebRequest方式
 

复制代码 代码示例:
private string GetHttpWebRequest(string url)
{
    Uri uri = new Uri(url);
    HttpWebRequest myReq = (HttpWebRequest)WebRequest.Create(uri);
    myReq.UserAgent = "User-Agent:Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.2; .NET CLR 1.0.3705";
    myReq.Accept = "*/*";
    myReq.KeepAlive = true;
    myReq.Headers.Add("Accept-Language", "zh-cn,en-us;q=0.5");
    HttpWebResponse result = (HttpWebResponse)myReq.GetResponse();
    Stream receviceStream = result.GetResponseStream();
    StreamReader readerOfStream = new StreamReader(receviceStream, System.Text.Encoding.GetEncoding("utf-8"));
    string strHTML = readerOfStream.ReadToEnd();
    readerOfStream.Close();
    receviceStream.Close();
    result.Close();
    return strHTML;
}
 

注意:“utf-8”应与指定网页的编码对应。

总结
HttpWebRequest 方式最复杂,但确提供了更多的选择性。
有的网站检测客户端的UserAgent!如163.com,如果使用WebClient WebRequest方式获取,将获取到的是错误提示页面的内容。
HttpWebRequest没有这个问题。
测试环境:WIN2003 + VS2005 + C# + winForm

附,本例中的代码下载:GetHtml.rar

您可能感兴趣的文章:
C# Winform获取网页源文件的实现方法
c# 天气预报查询(winform方法)的实现代码(图文)
C# Winform调用WEB Service API的示例代码
c# winform 手机号码归属地查询工具的实现代码(图文)
C# Winform中获取文件路径的方法
C# WinForm打开PDF文件
C# winform treeview添加右键菜单并选中节点的方法
c#实现DataGridView控件隔行变色(winform)的代码
C# Winform 操作 INI 配置文件的实现代码
关于.net的一些资源网站

[关闭]
~ ~