Requests 设置cookies方式

Lophole 2020-06-13

方法一:

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。

相关推荐