自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

一個爬蟲的故事:這是人干的事兒?

安全 應用安全
爬蟲原理我是一個爬蟲,每天穿行于互聯(lián)網(wǎng)之上,爬取我需要的一切。說起來還要感謝HTTP協(xié)議,因為它,全世界的網(wǎng)站和瀏覽器才能夠連接通信,而我也是借助HTTP協(xié)議,獲取我想要的數(shù)據(jù)。

[[345231]]

爬蟲原理我是一個爬蟲,每天穿行于互聯(lián)網(wǎng)之上,爬取我需要的一切。

 

說起來還要感謝HTTP協(xié)議,因為它,全世界的網(wǎng)站和瀏覽器才能夠連接通信,而我也是借助HTTP協(xié)議,獲取我想要的數(shù)據(jù)。

我只需要偽裝成一個瀏覽器,向服務器發(fā)送HTTP請求,就能拿到網(wǎng)頁HTML文件。

接著,我再按照HTML的格式規(guī)范,去解析其中的圖片、鏈接、表單

 

等等我關注的信息。

 

獲取鏈接標簽以后,我又可以進一步爬取鏈接背后的網(wǎng)頁,如此反復,要不了多久,一個網(wǎng)站中暴露出來的內(nèi)容我就能爬個干凈。

當然了,咱們做爬蟲也還是有底線的。干我們這一行,有一個約定俗成的規(guī)定,那就是Robots協(xié)議。

只要你在網(wǎng)站的根目錄下放置一個叫robots.txt的文件,里面寫上哪些目錄禁止訪問,我就會繞道而行,就像這樣:

  1. User-agent: * 
  2. Disallow: /a/ 
  3. Disallow: /b/ 
  4. Disallow: /c/ 

就像程序員們經(jīng)?;ハ啾梢曇粯?,在咱們爬蟲的圈子里,也存在鄙視鏈。

地位最高的要數(shù)搜索引擎的爬蟲了,他們高高在上,正大光明的爬,各個網(wǎng)站歡迎還來不及,都想被他們收錄到搜索引擎之中,給網(wǎng)站帶來流量。這些爬蟲,都是圈子里的大佬,我們?nèi)遣黄稹?/p>

 

另外有一些爬蟲,他們有的不遵守robots協(xié)議,隨意亂爬,有的一天天的凈知道爬美女圖片,把人家服務器爬崩潰了,這些爬蟲我們也是看不起的。

像我這樣老實本分的爬蟲,平日的工作就是爬取一些網(wǎng)站的數(shù)據(jù),像購物網(wǎng)站、點評網(wǎng)站等等。雖然我們很守規(guī)矩,但這些個網(wǎng)站還是很不待見我們,為了拿到數(shù)據(jù),我們展開了曠日持久的拉鋸戰(zhàn)。

 

反爬蟲技術

現(xiàn)在很多網(wǎng)站都上云了,云上的資源可昂貴了,CPU、內(nèi)存、存儲這些都價格不菲,尤其是網(wǎng)絡帶寬,價格是真心貴。

 

那些網(wǎng)站不待見咱們這些爬蟲也就可以理解了,我們不像搜索引擎爬蟲可以給他們帶來好處,相反,還會消耗他們的服務器性能,花掉他們寶貴的流量,那可是白花花的人民幣,誰不心疼啊?

所以這些網(wǎng)站加了一個措施:一旦在HTTP請求中的user-agent字段發(fā)現(xiàn)這是一個爬蟲,那就不搭理我們了。

 

這個user-agent是HTTP協(xié)議中表示客戶端名字的字段,那個時候我剛剛入行,沒什么經(jīng)驗,不懂得偽裝,很容易就被發(fā)現(xiàn)。

為了能夠繼續(xù)爬數(shù)據(jù),我只好改頭換面,偽裝成了瀏覽器的名字,圈子里有的兄弟還偽裝成了搜索引擎爬蟲的名字,我可不像他們那樣沒下線。

這一招管用了沒多久,這些網(wǎng)站就升級了策略,通過我們的行為來識別是不是真的瀏覽器。我們畢竟是程序,那速度比人類點擊快多了,網(wǎng)站一旦發(fā)現(xiàn)我們短時間內(nèi)發(fā)起了很多請求,那就掐斷連接。

我只好降低爬取的頻率,避免被拉入黑名單。

有些網(wǎng)站更狠,在網(wǎng)頁里面插入一些假的圖片,只有幾個像素那種,人類的眼睛是看不見的,但是我們不知道啊,對我來說都是標簽,我一訪問就中計了!立刻被拉入黑名單。

沒有辦法,攤上這種事,我只好想辦法換個IP再去爬,真是難頂。

聽說圈子里有些大佬用上了分布式技術,組團去爬,很多個IP地址,其中一個或者幾個封了也不用怕,我真是很羨慕。

前后端分離

在我的職業(yè)生涯中,遇到過一些奇怪的網(wǎng)站,明明網(wǎng)頁中有數(shù)據(jù),但是我一訪問拿到的HTML中啥也沒有,一度讓我很郁悶。

后來才知道,原來他們用上了一個叫前后端分離開發(fā)的技術,數(shù)據(jù)不再從服務器渲染到HTML網(wǎng)頁中,而是瀏覽器通過單獨的API接口拿到后再動態(tài)加載出來,難怪我拿到的只是一個空殼子。

 

為了拿到數(shù)據(jù),我只好也學著去請求這些數(shù)據(jù)接口,不過因為這些網(wǎng)站都有API網(wǎng)關,會檢查請求的Token或者Authorization之類的認證字段,再加上我不知道他們的接口參數(shù)格式,導致我經(jīng)常拿不到數(shù)據(jù)。

到了最近兩年,我拿到的網(wǎng)頁HTML越來越簡單了,在瀏覽器中豐富多彩的頁面,一查看源代碼竟然只有簡單幾行,真是見了鬼了!

終于有一天,一個前輩告訴我,現(xiàn)在流行單頁應用SPA了,頁面全都是在前端動態(tài)生成的,拿到的HTML根本沒有價值。

 

這簡直欺人太甚了!

一不做二不休,我決定弄一個真正的瀏覽器進來,這個內(nèi)嵌的瀏覽器沒有界面,專門為我服務,嵌入到我的程序中,讓他去真正的渲染網(wǎng)頁,渲染完成后我再去取數(shù)據(jù)!

這是真正意義上模擬人類去訪問網(wǎng)站了,再也不用模擬繁瑣的數(shù)據(jù)接口訪問,也不用擔心單頁應用,前端渲染就前端渲染,我再也不怕了!

驗證碼

到后來,不知道是誰發(fā)明的,網(wǎng)站們紛紛用上了一種叫驗證碼的技術,給我們出了難題。

開始的驗證碼還算比較簡單,一般都是些簡單的數(shù)字、英文字符做了些變形,就像這樣:

 

圈子里很快有大佬教我們用文字識別技術OCR來自動識別這種驗證碼,我也折騰了一下,費了老大勁終于可以識別出來,準確率不敢說100%,99%還是有的。

不過沒多久,這驗證碼就變得越來越復雜,什么漢字識別,物體識別,滑動解鎖,一個比一個難,根本超出了我的理解范圍,你瞧瞧下面這些驗證碼,這是人干的事兒嗎?

 

哎,這還真是人才能干的事,不是我們爬蟲能干的~

如今,這些網(wǎng)站的反爬蟲技術越來越先進,我們能發(fā)揮的空間被一步步擠壓。

前段時間,有個愣頭青爬蟲把一家公司的服務器給爬崩潰了,把人家正常業(yè)務都弄停掉了,他還被抓了起來,現(xiàn)在監(jiān)管越來越嚴,搞得大家人心惶惶。

內(nèi)憂外患不斷,不少爬蟲兄弟失業(yè)的失業(yè),轉行的轉行,爬蟲這碗飯,真是越來越不好吃了。。。

 

責任編輯:武曉燕 來源: 編程技術宇宙
相關推薦

2018-11-30 17:59:06

華為

2015-09-16 10:22:17

2020-12-12 13:50:16

云開發(fā)

2021-01-27 13:54:05

開發(fā)云原生工具

2015-08-13 14:35:43

2022-04-28 09:05:41

網(wǎng)絡爬蟲Python

2020-06-23 10:03:33

版本控制項目

2019-05-30 10:15:30

2012-11-29 09:49:17

軟件項目項目

2017-07-05 15:09:52

密碼token瀏覽器

2020-07-09 18:46:52

物聯(lián)網(wǎng)IIoT技術

2018-05-07 08:19:28

2017-12-14 14:36:54

金融工具敏捷大房間計劃

2017-06-02 08:48:29

互斥鎖JavaCAS

2018-06-05 15:41:22

進程線程協(xié)程

2017-09-13 15:45:17

交付軟件遺留系統(tǒng)

2018-07-03 15:20:36

Promise函數(shù)借錢

2014-10-21 11:11:08

Siri人工智能

2021-07-12 05:01:11

云原生軟件架構

2009-09-01 16:03:32

C#單元測試
點贊
收藏

51CTO技術棧公眾號