方法一:
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。