如何在requests session中手动设置cookie

最近工作中在使用python requests库时遇到一个问题,就是如何在session中设置对所有请求都生效的cookie?requests中的session对象一大特性就是它会自动为你管理cookie,当你登录一个页面时,它可以自动识别response中的set cookie头,然后为下面的请求一直维持这个cookie。不过我在使用的过程中,因为目标网站登录有验证码,所以打算每次运行时手动登录页面获取cookie,然后再把cookie写到代码变量中。这里遇到的问题就是当在get函数中传入cookie变量时,cookie只对当前的请求进行生效,下一次调用get还需要再传入一次cookie,否则发出去的请求是默认不会带有cookie的。

如下:

import requests
import time

mycookie = { "PHPSESSID":"56v9clgo1kdfo3q5q8ck0aaaaa" }
x = requests.session()
x.get("http://127.0.0.1:80",cookies = mycookie)
time.sleep(5)
x.get("http://127.0.0.1:80")

运行脚本后,通过抓包发现,第一次get请求的中含有我自定义的cookie,第二次请求中却没有。因为我要对很多http接口发送请求,所以如果在每个get里面都加入一个cookie变量的话,写起来就有些麻烦了。于是google了一下,找到了如下的解决方法:

import requests
import time

mycookie = { "PHPSESSID":"56v9clgo1kdfo3q5q8ck0aaaaa" }
x = requests.session()
requests.utils.add_dict_to_cookiejar(x.cookies,{"PHPSESSID":"07et4ol1g7ttb0bnjmbiqjhp43"})
x.get("http://127.0.0.1:80",cookies = mycookie)
time.sleep(5)
x.get("http://127.0.0.1:80")

这样,通过requests.utils.add_dict_to_cookiejar对session对象设置cookie,之后所有的请求都会自动加上我自定义的cookie内容。

也可以通过requests.utils.cookiejar_from_dict 先生成一个cookiejar对象,时候在赋值给session.cookies。貌似还可以使用session.cookies.set()或者update()。


### 回答1: 是什么?requests.session()是Python的一个HTTP会话对象,它可以跨请求保持某些参数,比如cookies、headers等。它允许你在连续的请求之间保存某些参数,而不必在每次请求都进行设置。 ### 回答2: 在Pythonrequests.session()是一个用于发送HTTP请求并保持会话的类。它可以用于多个请求之间共享会话状态和cookie息。 使用requests.session(),我们可以创建一个会话对象,并使用这个对象发送HTTP请求。会话对象会自动处理和跟踪请求之间的会话状态,例如保存cookie、处理重定向、处理会话级别的认证等。 使用requests.session()的主要好处是可以在一个会话保持会话状态,避免每次请求都重新建立连接和处理认证等环节,提高了效率并简化了代码。同时,会话对象还可以自动处理cookie的保存和发送,使得在多个请求共享cookie变得非常容易。 以下是一个使用requests.session()的简单示例: ```python import requests # 创建会话对象 session = requests.session() # 发送GET请求 response = session.get('https://www.example.com') # 发送POST请求 payload = {'username': 'user', 'password': 'pass'} response = session.post('https://www.example.com/login', data=payload) # 在会话保持会话状态和cookie息 response = session.get('https://www.example.com/profile') # 关闭会话 session.close() ``` 在上述示例,我们首先创建了一个会话对象session,并使用session发送了多个请求。在后续的请求,会话对象会自动处理和保存会话状态和cookie息。 总之,requests.session()提供了一种方便的方式来创建和管理HTTP会话,保持会话状态和共享cookie息。这在需要保持会话和处理多个请求的情况下非常有用,使得代码更加高效和简洁。 ### 回答3: 在Python,`requests.session()`是一个用于创建会话对象的方法。会话对象是在发送多个HTTP请求时使用的一种机制。使用会话对象可以实现以下功能: 1. 在多个请求之间共享同一个会话状态,这意味着您可以使用相同的会话对象发送多个请求,而不需要重新建立连接和认证。 2. 自动处理cookie,会话对象会自动保存和发送请求cookie息,使您无需手动处理cookie。 3. 支持持久连接,会话对象会在每次请求之间保持连接状态,从而提高请求的性能。 4. 提供便捷的方法发送GET、POST等HTTP请求,您可以通过会话对象的方法(如`get()`、`post()`等)发送请求,而无需每次都重新创建请求对象。 以下是一个使用`requests.session()`的简单示例: ```python import requests # 创建会话对象 session = requests.session() # 发送GET请求 response = session.get('http://example.com') # 打印响应内容 print(response.text) # 发送POST请求 data = {'username': 'admin', 'password': 'password'} response = session.post('http://example.com/login', data=data) # 打印响应状态码 print(response.status_code) # 关闭会话 session.close() ``` 在上面的示例,首先我们创建了一个会话对象`session`,然后使用该对象发送了一个GET请求,并打印了响应内容。接下来,我们使用同一个会话对象发送了一个POST请求,传递了用户名和密码作为表单数据。最后,我们关闭了会话对象。 总结来说,`requests.session()`方法是用于创建会话对象的,通过会话对象可以方便地处理多个HTTP请求,并提供了一些便捷的方法来发送请求和处理响应。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值