亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

模擬HTTP請求實現(xiàn)網(wǎng)頁自動操作及數(shù)據(jù)采集的方法

 更新時間:2017年03月27日 10:00:30   投稿:jingxian  
下面小編就為大家?guī)硪黄MHTTP請求實現(xiàn)網(wǎng)頁自動操作及數(shù)據(jù)采集的方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

前言

網(wǎng)頁可分為信息提供和業(yè)務操作類,信息提供如新聞、股票行情之類的網(wǎng)站。業(yè)務操作如網(wǎng)上營業(yè)廳、OA之類的。當然,也有很多網(wǎng)站同時具有這兩種性質(zhì),像微博、豆瓣、淘寶這類網(wǎng)站,既提供信息,也實現(xiàn)某些業(yè)務。

普通上網(wǎng)方式一般都是手動操作(這個不需要解釋:D)。但有時候人工手動操作的方式可能就無法勝任了,如爬取網(wǎng)絡上大量數(shù)據(jù),實時監(jiān)測某個頁面的變化,批量操作業(yè)務(如批量發(fā)微博,批量淘寶購物)、刷單等。由于操作量大,而且都是重復的操作,人工操作效率低下,且易出錯。這時候就可以使用軟件來自動操作了。

本人開發(fā)過多個這類軟件,有網(wǎng)絡爬蟲、自動批量操作業(yè)務這類的。其中使用到的一個核心功能就是模擬HTTP請求。當然,有時會使用HTTPS協(xié)議,而且網(wǎng)站一般需要登陸后才能進一步操作,還有最重要的一點就是弄清楚網(wǎng)站的業(yè)務流程,即知道為了實現(xiàn)某個操作該在什么時候向哪個頁面以什么方式提交什么數(shù)據(jù),最后,要提取數(shù)據(jù)或知道操作結(jié)果,就還需要解析HTML。本文將一一闡述。

本文使用C#語言來展示代碼,當然也可以用其它語言實現(xiàn),原理是一樣的。以登陸京東為實例。

模擬HTTP請求

C#模擬HTTP請求需要使用到如下類:

•WebRequest

•HttpWebRequest

•HttpWebResponse

•Stream

先創(chuàng)建一個請求對象(HttpWebRequest),設置相關的Headers信息后發(fā)送請求(如果是POST,還要把表單數(shù)據(jù)寫入網(wǎng)絡流),如果目標地址可訪問,會得到一個響應對象(HttpWebResponse),從相應對象的網(wǎng)絡流中就可讀出返回結(jié)果。

示例代碼如下:

String contentType = "application/x-www-form-urlencoded";
String accept = "image/gif, image/x-xbitmap, image/jpeg, image/pjpeg, application/x-shockwave-flash, application/x-silverlight, application/vnd.ms-excel, application/vnd.ms-powerpoint, application/msword, application/x-ms-application, application/x-ms-xbap, application/vnd.ms-xpsdocument, application/xaml+xml, application/x-silverlight-2-b1, */*";
String userAgent = "Mozilla/5.0 (Windows NT 6.3; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/34.0.1847.116 Safari/537.36";

public String Get(String url, String encode = DEFAULT_ENCODE)
{
   HttpWebRequest request = WebRequest.Create(url) as HttpWebRequest;
   InitHttpWebRequestHeaders(request);
   request.Method = "GET";
   var html = ReadHtml(request, encode);
   return html;
}

public String Post(String url, String param, String encode = DEFAULT_ENCODE)
{
   Encoding encoding = System.Text.Encoding.UTF8;
   byte[] data = encoding.GetBytes(param);
   HttpWebRequest request = WebRequest.Create(url) as HttpWebRequest;
   InitHttpWebRequestHeaders(request);
   request.Method = "POST";
   request.ContentLength = data.Length;
   var outstream = request.GetRequestStream();
   outstream.Write(data, 0, data.Length);
   var html = ReadHtml(request, encode);
   return html;
}

private void InitHttpWebRequestHeaders(HttpWebRequest request)
{
  request.ContentType = contentType;
  request.Accept = accept;
  request.UserAgent = userAgent;
}

private String ReadHtml(HttpWebRequest request, String encode)
{
  HttpWebResponse response = request.GetResponse() as HttpWebResponse;
  Stream stream = response.GetResponseStream();
  StreamReader reader = new StreamReader(stream, Encoding.GetEncoding(encode));
  String content = reader.ReadToEnd();
  reader.Close();
  stream.Close();
  return content;
}

可以看出,Get和Post方法的代碼大部分都相似,所以代碼進行了封裝,提取了相同代碼作為新的函數(shù)。

HTTPS請求

當網(wǎng)站使用https協(xié)議時,以上代碼就可能會出現(xiàn)以下錯誤:

The underlying connection was closed: Could not establish trust relationship for 

原因是證書錯誤,用瀏覽器打開會出現(xiàn)如下頁面:

當點擊繼續(xù)前往xxx.xx(不安全)時,就可繼續(xù)打開網(wǎng)頁。在程序中,也只要模擬這一步就可以繼續(xù)了。C#中只需設置ServicePointManager.ServerCertificateValidationCallback代理,在代理方法中直接返回true就行了。

private HttpWebRequest CreateHttpWebRequest(String url)
{
  HttpWebRequest request;
  if (IsHttpsProtocol(url))
  {
    ServicePointManager.ServerCertificateValidationCallback = new RemoteCertificateValidationCallback(CheckValidationResult);
    request = WebRequest.Create(url) as HttpWebRequest;
    request.ProtocolVersion = HttpVersion.Version10;
  }
  else
  {
    request = WebRequest.Create(url) as HttpWebRequest;
  }

  return request;
}

private HttpWebRequest CreateHttpWebRequest(String url)
{
  HttpWebRequest request;
  if (IsHttpsProtocol(url))
  {
    ServicePointManager.ServerCertificateValidationCallback = new RemoteCertificateValidationCallback(CheckValidationResult);
    request = WebRequest.Create(url) as HttpWebRequest;
    request.ProtocolVersion = HttpVersion.Version10;
  }
  else
  {
    request = WebRequest.Create(url) as HttpWebRequest;
  }

  return request;
}


這樣,就可正常訪問https網(wǎng)站了。

記錄Cookies實現(xiàn)身份認證

有些網(wǎng)站需要登錄才能執(zhí)行下一步操作,比如在京東購物需要先登錄。網(wǎng)站服務器使用session來記錄客戶端用戶,每一個session對應一個用戶,而前面的代碼每次創(chuàng)建一個請求都會重新建立一個session。即使登錄成功,在執(zhí)行下一步操作由于新創(chuàng)建了一個連接,登錄也是無效的。這時就得想辦法讓服務器認為這一系列的請求來自同一個session。

客戶端只有Cookies,為了在下次請求的時候讓服務器知道該客戶端對應哪個session,Cookies中會有一個記錄session ID的記錄。所以,只要Cookies相同,對服務器來說就是同一個用戶。

這時需要使用到CookieContainer,顧名思義,這就是一個Cookies容器。HttpWebRequest有一個CookieContainer屬性。只要把每次請求的Cookies都記錄在CookieContainer,下次請求時設置HttpWebRequest的CookieContainer屬性,由于Cookies相同,對于服務器來說就是同一個用戶了。

public String Get(String url, String encode = DEFAULT_ENCODE)
{
   HttpWebRequest request = WebRequest.Create(url) as HttpWebRequest;
   InitHttpWebRequestHeaders(request);
   request.Method = "GET";

   request.CookieContainer = cookieContainer;
   HttpWebResponse response = request.GetResponse() as HttpWebResponse;
   foreach (Cookie c in response.Cookies)
   {
      cookieContainer.Add(c);
   }
}

分析調(diào)試網(wǎng)站

以上就實現(xiàn)了模擬HTTP請求,當然,最重要的還是分析站。一般的情況都是沒有文檔、找不到網(wǎng)站開發(fā)人員,從一個黑盒子開始探索。分析工具有很多,推薦使用Chrome+插件Advanced Rest Client,Chrome的開發(fā)者工具能讓我們知道打開一個網(wǎng)頁時后臺做了哪些操作與請求,Advanced Rest Client可模擬發(fā)送請求。

比如在登錄京東時,會提交如下數(shù)據(jù):

我們還能看到京東的密碼居然是明文傳輸,安全性很讓人擔心?。?/p>

還能看到返回的數(shù)據(jù):

返回的是JSON數(shù)據(jù),不過\u8d26這些是什么?其實這是Unicode編碼,使用Unicode編碼轉(zhuǎn)換工具,即可轉(zhuǎn)換成可讀的文字,比如這次返回的結(jié)果是:賬戶名與密碼不匹配,請重新輸入。

解析HTML

HTTP請求獲得的數(shù)據(jù)一般是HTML格式,有時也可能是Json或XML。需要解析才能提取有用數(shù)據(jù)。解析HTML的組件有:

•HTML Parser。多個平臺可用,如Java/C#/Python。很久沒用了。

•HtmlAgilityPack。通過通過XPath來解析HMTL。一直使用。 關于XPath教程,可以看W3School的XPath教程。

結(jié)語

本文介紹了開發(fā)模擬自動網(wǎng)頁操作所需要的技能,從模擬HTTP/HTTPS請求,到Cookies、分析網(wǎng)站、解析HTML。代碼旨在說明使用方法,并非完整代碼,可能無法直接運行。

以上這篇模擬HTTP請求實現(xiàn)網(wǎng)頁自動操作及數(shù)據(jù)采集的方法就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

  • 用類的繼承關系(重寫父類的方法)實現(xiàn)簡易后臺代碼模板

    用類的繼承關系(重寫父類的方法)實現(xiàn)簡易后臺代碼模板

    Asp.net的優(yōu)勢就在于快速構(gòu)建應用,而對于一些最基礎數(shù)據(jù)的增刪改以及分頁事件或者樣式的設定可以通過在父類中寫上虛方法來供子類調(diào)用,接下來將為您測試一下用子類重寫父類的方法實現(xiàn)在模板的基礎上衍生變化
    2013-01-01
  • Discuz .net版本中的短消息系統(tǒng)

    Discuz .net版本中的短消息系統(tǒng)

    Discuz .net 短消息實現(xiàn)原理。
    2009-04-04
  • asp.net TripleDES加密、解密算法

    asp.net TripleDES加密、解密算法

    加密,使用密碼產(chǎn)生加密算法的公鑰,并使用TripleDES對密碼進行加密。解密,使用密碼產(chǎn)生加密算法的公鑰,并使用TripleDES對加密數(shù)據(jù)進行解密。
    2008-08-08
  • CefSharp v62修改方法(支持.net4.0)

    CefSharp v62修改方法(支持.net4.0)

    下面小編就為大家分享一篇CefSharp v62修改方法(支持.net4.0),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2017-12-12
  • 把程序集安裝到全局程序集緩存中的步驟

    把程序集安裝到全局程序集緩存中的步驟

    最近兩天在看網(wǎng)絡編程中制作簡單的http服務器,其中用到把程序集安裝到全局程序集緩存中,自己嘗試了一下,記錄一下:(首先,對共享程序集安裝計算機管理員權限)
    2008-11-11
  • C# new和override的區(qū)別分析

    C# new和override的區(qū)別分析

    C# new和override都會覆蓋父類中的方法。那它們兩者之前有什么區(qū)別呢?
    2013-03-03
  • ASP.NET?MVC5網(wǎng)站開發(fā)顯示文章列表(九)

    ASP.NET?MVC5網(wǎng)站開發(fā)顯示文章列表(九)

    顯示文章列表分兩塊,管理員可以顯示全部文章列表,一般用戶只顯示自己的文章列表。文章列表的顯示采用easyui-datagrid,后臺需要與之對應的action返回json類型數(shù)據(jù),感興趣的小伙伴們可以參考一下
    2015-09-09
  • ASP.NET?Core設置Ocelot網(wǎng)關限流

    ASP.NET?Core設置Ocelot網(wǎng)關限流

    這篇文章介紹了ASP.NET?Core設置Ocelot網(wǎng)關限流的方法,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-04-04
  • .Net MVC將Controller數(shù)據(jù)傳遞到View

    .Net MVC將Controller數(shù)據(jù)傳遞到View

    這篇文章介紹了.Net MVC將Controller數(shù)據(jù)傳遞到View的方法,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-03-03
  • ASP.net 路徑問題 詳細說明

    ASP.net 路徑問題 詳細說明

    能詳細解釋一下:Request.ApplicationPath,~/,/,./,../及其用法(可時用)嗎?老是在相對路徑問題上出錯。 問題點數(shù)
    2009-06-06

最新評論