python 爬蟲出現(xiàn)403禁止訪問錯誤詳解
python 爬蟲解決403禁止訪問錯誤
在Python寫爬蟲的時候,html.getcode()會遇到403禁止訪問的問題,這是網(wǎng)站對自動化爬蟲的禁止,要解決這個問題,需要用到python的模塊urllib2模塊
urllib2模塊是屬于一個進階的爬蟲抓取模塊,有非常多的方法,比方說連接url=//www.dhdzp.com/qysh123對于這個連接就有可能出現(xiàn)403禁止訪問的問題
解決這個問題,需要以下幾步驟:
<span style="font-size:18px;">req = urllib2.Request(url)
req.add_header("User-Agent","Mozilla/5.0 (Windows NT 6.3; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/39.0.2171.95 Safari/537.36")
req.add_header("GET",url)
req.add_header("Host","blog.csdn.net")
req.add_header("Referer","http://www.dhdzp.com/")
其中User-Agent是瀏覽器特有的屬性,通過瀏覽器查看源代碼就可以查看到
然后
html=urllib2.urlopen(req) print html.read()
就可以把網(wǎng)頁代碼全部下載下來,而沒有了403禁止訪問的問題。
對于以上問題,可以封裝成函數(shù),供以后調(diào)用方便使用,具體代碼:
#-*-coding:utf-8-*-
import urllib2
import random
url="http://www.dhdzp.com/article/1.htm"
my_headers=["Mozilla/5.0 (Windows NT 6.3; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/39.0.2171.95 Safari/537.36",
"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_9_2) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/35.0.1916.153 Safari/537.36",
"Mozilla/5.0 (Windows NT 6.1; WOW64; rv:30.0) Gecko/20100101 Firefox/30.0"
"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_9_2) AppleWebKit/537.75.14 (KHTML, like Gecko) Version/7.0.3 Safari/537.75.14",
"Mozilla/5.0 (compatible; MSIE 10.0; Windows NT 6.2; Win64; x64; Trident/6.0)"
]
def get_content(url,headers):
'''''
@獲取403禁止訪問的網(wǎng)頁
'''
randdom_header=random.choice(headers)
req=urllib2.Request(url)
req.add_header("User-Agent",randdom_header)
req.add_header("Host","blog.csdn.net")
req.add_header("Referer","http://www.dhdzp.com/")
req.add_header("GET",url)
content=urllib2.urlopen(req).read()
return content
print get_content(url,my_headers)
其中用到了random隨機函數(shù),自動獲取已經(jīng)寫好的瀏覽器類型的User-Agent信息,在自定義函數(shù)中需要寫出自己的Host,Referer,GET信息等,解決這幾個問題,就可以順利訪問了,不再出現(xiàn)403訪問的信息。
當然如果訪問頻率過快的話,有些網(wǎng)站還是會過濾的,解決這個需要用到代理IP的方法。。。具體的自己解決
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
相關(guān)文章
Python實現(xiàn)普通圖片轉(zhuǎn)ico圖標的方法詳解
ICO是一種圖標文件格式,圖標文件可以存儲單個圖案、多尺寸、多色板的圖標文件。本文將利用Python實現(xiàn)普通圖片轉(zhuǎn)ico圖標,感興趣的小伙伴可以了解一下2022-11-11
Python實現(xiàn)更改圖片尺寸大小的方法(基于Pillow包)
這篇文章主要介紹了Python實現(xiàn)更改圖片尺寸大小的方法,結(jié)合實例形式分析了Python基于Pillow包更改圖片屬性的相關(guān)技巧,需要的朋友可以參考下2016-09-09
Python使用tkinter模塊實現(xiàn)GUI界面的學(xué)生信息管理系統(tǒng)流程分步詳解
這篇文章主要為大家詳細介紹了python實現(xiàn)簡易學(xué)生信息管理系統(tǒng),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2023-01-01
Django 設(shè)置admin后臺表和App(應(yīng)用)為中文名的操作方法
這篇文章主要介紹了Django 設(shè)置admin后臺表和App(應(yīng)用)為中文名的操作方法,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-05-05

