Requests 設置cookies方式


方法一:

cookie是字典格式

import requests

cookies_value = {'name1': 'value1', 
                 'name2': 'value2'}
response = requests.post(url=url,
                         data=data,
                         cookies=cookies_value

方法二:

cookies存放在headers中

header = {
    "cookie": "cookie_name=cookie_value;cookie_name=cookie_value"
}
response = session.post(url=url,
                        headers=header,
                        params=param,
                        data=data
                        )

 

方式三:使用session

3.1

session = requests.session()
session.cookies['cookie_name'] = "cookies_value"

 

功能:可以添加cookie,不會清除原有的cookie

缺點:不能設置path,domain

使用:可以在登錄時將驗證碼的Cookie添加進去

3.2

session = requests.session()
session.cookies.set('cookie_name', "cookie_value", path='/', domain='.abc.com')

功能:設置path、domain等參數

缺點:清除原來的cookies

3.3

session = requests.session()
requests.utils.add_dict_to_cookiejar(session.cookies, cookie_dict)

功能:可以添加cookie,不會清除原有的cookie

缺點:不能設置path,domain等參數

3.4

session = requests.Session()
c = requests.cookies.RequestsCookieJar()
c.set('cookie_name', 'cookie_value') #path='/', domain='.abc.com'
session.cookies.update(c)
session.get(url='http://47.107.178.45/phpwind/')

 小知識

cookie的path和domain屬性

  domain表示的是cookie所在的域,默認為請求的地址,如網址為www.test.com/test/test.aspx,那么domain默認為www.test.com。而跨域訪問,如域A為t1.test.com,域B為t2.test.com,那么在域A生產一個域A和域B都能訪問的cookie將要將該cookie的domain設置為.test.com;如果要在域A生產一個令域A不能訪問而域B能訪問的cookie就要將該cookie的domain設置為t2.test.com。

  path表示cookie所在的目錄,asp.net默認為/,就是根目錄。在同一個服務器上有目錄如下:/test/,/test/ccd/,/test/dd/,現設要給cookie1的path為/test,cookie2的path為/test/cd/,那么test下的所有頁面都可以訪問到cookie1,而/test/和/test/dd/的子頁面不能訪問cookie2。這是因為cookie能讓其path路徑下的頁面訪問。

  瀏覽器會將domain和path都相同的cookie保存在一個文件里,cookie間用*隔開。含值鍵值對的cookie:以前一直用的是name=value單鍵值對的cookie,含多個子鍵值對的cookie格式是name=key1=value1&key2=value2。

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM