Python Requests使用Cookie的几种方式

 

本文主要给大家介绍了关于Python Requests使用Cookie的几种方式,Python中的requests库可以使用cookie来维持会话状态,实现登录等操作,需要的朋友可以参考下

一、通过headers参数使用

通过headers参数使用cookie,key为Cookie,值为使用;拼接的 cookie_name=cookie_value 字符串

1

2

3

4

5

6

7

8

9

10

import requests

get_url = "https://postman-echo.com/get"

# key为Cookie,值为使用;拼接的 cookie_name=cookie_value 字符串

headers = {"Cookie":"cka=111a;ckb=111b"}

res = requests.get(url=get_url,headers=headers)

print(res.json().get("headers").get("cookie"))

print(res.request.headers.get("Cookie"))

输出如下:

cka=111a;ckb=111b
cka=111a;ckb=111b

二、通过cookies参数使用

通过cookies参数使用cookie,cookies 值以字典形式提供,key为cookie_name,value为cookie_value

1

2

3

4

5

6

7

8

9

10

import requests

get_url = "https://postman-echo.com/get"

# cookies 以字典形式提供,cookies 值以字典形式提供,key为cookie_name,value为cookie_value

cookies = {"cka":"222a","ckb":"222b"}

res = requests.get(url=get_url,cookies=cookies)

print(res.json().get("headers").get("cookie"))

print(res.request.headers.get("Cookie"))

输出:

cka=222a; ckb=222b
cka=222a; ckb=222b

注意:同时通过headers,cookies 参数传递Cookie时,只有headers传递的Cookie有效。

三、通过Session会话使用

通过Session会话管理Cookie,同一会话的多个请求可共享Cookie;

在Session中添加Cookie又有多种方式

方式0:自动设置

在会话过程中,如果有接口响应头中有 set-cookie,则将自动添加到会话的Cookie中

1

2

3

4

5

6

7

8

9

10

import requests

session = requests.session()

print("会话初始cookie:",dict(session.cookies))

get_url = "https://postman-echo.com/get"

res = session.get(url=get_url)

print("响应头中set-cookie:",res.headers.get("set-cookie"))

print("会话现有cookie:",dict(session.cookies))

输出:

会话初始cookie: {}
响应头中set-cookie: sails.sid=s%3ALo1-iQfueg8z1DhR_SX3KxwWA85cYN65.asZ1elFlT9g54uj%2FHkHpaZFkk0rBaCFDtRrA9anWzY4; Path=/; HttpOnly
会话现有cookie: {'sails.sid': 's%3ALo1-iQfueg8z1DhR_SX3KxwWA85cYN65.asZ1elFlT9g54uj%2FHkHpaZFkk0rBaCFDtRrA9anWzY4'}

方式1:通过key设置

直接通过key设置cookie,但不支持设置cookie的 path、domain 等值

1

2

3

4

5

6

7

8

9

10

11

12

13

14

import requests

session = requests.session()

print("会话初始cookie:",dict(session.cookies))

# 直接通过key设置cookie,但不支持设置cookie的 path、domain 等值

session.cookies["cka"]="111a"

session.cookies["ckb"]="111b"

get_url = "https://postman-echo.com/get"

res = session.get(url=get_url)

print("本次请求使用的cookie:",res.request.headers.get("Cookie"))

print("会话现有cookie:",dict(session.cookies))

输出:

会话初始cookie: {}
本次请求使用的cookie: cka=111a; ckb=111b
会话现有cookie: {'cka': '111a', 'ckb': '111b', 'sails.sid': 's%3AxtcEChogQfCYrRm9HDwAOFa4VlQQDsCZ.OR1TBpmuhX%2F2qI7mpTE0NdChrphD5AUcvcRqUF2y6NU'}

方式2:通过set 方法设置

通过set方法设置cookie,且支持设置path、domain等值

1

2

3

4

5

6

7

8

9

10

11

12

13

import requests

session = requests.session()

print("会话初始cookie:",dict(session.cookies))

# 通过set方法设置cookie,且支持设置path、domain等值

session.cookies.set("ck2","222",path="/",domain="postman-echo.com")

get_url = "https://postman-echo.com/get"

res = session.get(url=get_url)

print("本次请求使用的cookie:",res.request.headers.get("Cookie"))

print("会话现有cookie:",session.cookies)

输出:

会话初始cookie: {}
本次请求使用的cookie: ck2=222
会话现有cookie: <RequestsCookieJar[<Cookie ck2=222 for postman-echo.com/>, <Cookie sails.sid=s%3AZW2JtlIjc1m9D2vVrn1Io57gVB6lVQiK.SjYcItCh92iqDkVF7oI8C6q5P8KmQ5DwB%2BiD4A6Ag48 for postman-echo.com/>]>

注意:<Cookie ck2=222 for postman-echo.com/> 可以看出 设置的 path、domain 成功了

方式3:通过 add_dict_to_cookiejar 方法设置

通过 requests.utils 工具包里的 add_dict_to_cookiejar 方法设置cookie,但不支持设置 path、domain 等值

1

2

3

4

5

6

7

8

9

10

11

12

13

14

import requests

session = requests.session()

print("会话初始cookie:",dict(session.cookies))

# 通过 requests.utils 工具包里的 add_dict_to_cookiejar 方法设置cookie,但不支持设置 path、domain 等值

cookie_dict = {"ck3a":"333a","ck3b":"333b"}

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

get_url = "https://postman-echo.com/get"

res = session.get(url=get_url)

print("本次请求使用的cookie:",res.request.headers.get("Cookie"))

print("会话现有cookie:",dict(session.cookies))

输出:

会话初始cookie: {}
本次请求使用的cookie: ck3a=333a; ck3b=333b
会话现有cookie: {'ck3a': '333a', 'ck3b': '333b', 'sails.sid': 's%3AFY_7nq-hA_v9BxPaft4BHgRNiZOmDZ1S.N64IaIZ2Dd2fnfDMawbXdmJl0HfUVN7hhhGrdaFE4Bs'}

方式4:通过 RequestsCookieJar() 对象设置

创建一个空 RequestsCookieJar()对象,然后使用对象的set方法赋值,然后update更新到当前会话cookie,支持设置 path、domain等值

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

import requests

session = requests.session()

print("会话初始cookie:",dict(session.cookies))

# 创建一个空 RequestsCookieJar()对象,然后使用对象的set方法赋值,然后update更新到当前会话cookie,支持设置 path、domain等值

ckj = requests.sessions.RequestsCookieJar()

ckj.set('ck4a', '444a', path='/', domain='postman-echo.com')

session.cookies.update(ckj)

get_url = "https://postman-echo.com/get"

res = session.get(url=get_url)

print("本次请求使用的cookie:",res.request.headers.get("Cookie"))

print("会话现有cookie:",dict(session.cookies))

输出:

会话初始cookie: {}
本次请求使用的cookie: ck4a=444a
会话现有cookie: {'ck4a': '444a', 'sails.sid': 's%3ANU88BiSVQAFpVUtrvSrii14jOhO_q981.MfJkY7Aw93R0Rc4V6JGi7SXPOneNJTr3p%2FNVJ9yp4Qg'}

方式5:通过 cookiejar_from_dict 方法设置

通过 requests.utils 工具包里的 cookiejar_from_dict 方法将字典格式的cookie转换为cookiejar对象,然后update更新到当前会话,不支持设置 path、domain 等值

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

import requests

session = requests.session()

print("会话初始cookie:",dict(session.cookies))

# 通过 requests.utils 工具包里的 cookiejar_from_dict 方法将字典格式的cookie转换为cookiejar对象,然后update更新到当前会话,不支持设置 path、domain 等值

cookie_dict = {"ck5a":"555a","ck5b":"555b"}

ckj5 = requests.utils.cookiejar_from_dict(cookie_dict=cookie_dict)

session.cookies.update(ckj5)

get_url = "https://postman-echo.com/get"

res = session.get(url=get_url)

print("本次请求使用的cookie:",res.request.headers.get("Cookie"))

print("会话现有cookie:",dict(session.cookies))

输出:

会话初始cookie: {}
本次请求使用的cookie: ck5a=555a; ck5b=555b
会话现有cookie: {'ck5a': '555a', 'ck5b': '555b', 'sails.sid': 's%3AWHa__ab1vTZVjGdlIpDgDFfntSYNqS2Y.y%2Fq4YhPv49C5jwNiYdVWrFsQm9B0Y202rI5xRrqlwsk'}

总结

到此这篇关于Python Requests使用Cookie的几种方式的文章就介绍到这了,希望可以帮到你

转自:微点阅读   https://www.weidianyuedu.com

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值