總結
調試網站獲取cookies時請查看,r.header和r.request.header這兩個屬性,因為cookie說不準出現在他們倆誰里面。
先貼一個代碼
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
|
import re import requests from bs4 import BeautifulSoup def printHeaders(headers): for h in headers: print (h + " : " + headers[h] + '\r\n' ) def printCookies(cookies): for h in cookies: print (h + " : " + cookies[h] + '\r\n' ) def loginFw( id ,password): url = "http://xxxxx/login.asp" try : headers = { 'user-agent' : 'Mozilla/5.0 (Windows NT 10.0; WOW64; rv:55.0) Gecko/20100101 Firefox/55.0' , 'Host' : 'www.xxx.org' , 'Accept' : 'text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8' , 'Accept-Language' : 'zh-CN,zh;q=0.8,en-US;q=0.5,en;q=0.3' , 'Accept-Encoding' : 'gzip, deflate' , 'Content-Type' : 'application/x-www-form-urlencoded' , 'Referer' : 'http://xxx/login.asp' , 'Connection' : 'keep-alive' , } params = { "Reglname" : id , "reglpassword" :password} r = requests.post(url,data = params,headers = headers) printHeaders(r.headers) #這里是獲取不到服務器返回的cookie的 r.encoding = 'utf-8' return r.text except Exception as e: print ( "登陸錯誤:" + str (e)) #print(ret) |
事情經過
事情的發生是這樣的,今天我在調試一個網站的模擬登陸,但是怎么調試都調試不出來這個網站返回的cookie(因為我是用r.headers來獲取cookies的),后來我就在想是不是我的請求頭沒有設置正確,然后我就遍歷了r.request.headers,然后這個變量如實的打印了我的請求頭的信息,但是我仔細一看cookie怎么出現了變化,咦,這不就是我需要的響應cookie嗎!
難道是我對r.request這個對象的理解出錯了嗎?以前我一直認為這個對象里面存儲的是我請求發出去的信息,現在怎么會出現響應cookie呢?
就在我百撕不得其解的時候,我去翻閱了requests庫的官方文檔關于respond對象中包含的request的解釋,它上面寫著“The PreparedRequest object to which this is a response.”(表示看不到什么意思,百度翻譯也翻譯不清楚),咦,好像是和響應有關啊,看來應該是我的理解出現了錯誤。
更好的解決方案
那當然是用requests提供的"會話對象",他能夠自動的保留請求所獲取的參數。
具體請跳轉傳送門:
http://cn.python-requests.org/zh_CN/latest/user/advanced.html#request-and-response-objects
后來
后來我發現原來是因為我在請求頭里面寫了“Host”,“Referer”,導致Cookie出現異常的原因,所以以后不要隨便寫這兩個參數了,要寫就照著封包里的寫。
以上這篇python獲取服務器響應cookie的實例就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持服務器之家。
原文鏈接:https://blog.csdn.net/a735311619/article/details/78093738