requests中cookie传递的几种方式

学习到了接口测试中传递cookie的几种方式,总结给大家。

方法一:通过会话保持(最建议的方式)

import requests

s = requests.Session()

#进行登录
r = s.post(url = url, headers = headers, data = data)

#登录后的其他操作
r1 = s.post(url = url, headers = headers, data = data)

方法二:通过传递cookie

import requests

#进行登录
r = requests.post(url = url, headers = headers,data = data)

#可以打印cookie出来看看
print(r.headers['Set-Cookie'])



#登录后的其他操作
r1 = requests.post(url = url, headers = headers,data = data, cookie = r.cookies)

#将响应内容打印出来对比
print(r1.text)

方法三:通过更新header

import requests


header = {……}

#进行登录
r = requests.post(url = url, headers = header,data = data)

#打印cookie
print(r.headers['Set-Cookie'])


#更新header
header.update({'Cookie':r.headers['Set-Cookie']})

#登录后的其他操作
r1 = requests.post(url = url, headers = header,data = data)

#查看r1的响应结果
print(r1.text)

方法四:通过将cookie放在header中

import requests


#进行登录
r = requests.post(url = url, headers = header,data = data)

#取出登录中的cookie,放在header中
header = {……, 'cookie':'……'}

#进行登录后的其他操作
r1 = requests.post(url = url, headers = header,data = data)
print(r1.text)

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: requests headers指的是使用Pythonrequests库发送请求时,可以设置的请求头部信息。请求头部信息是包含在HTTP请求的一些元数据,用于告诉服务器关于请求的更多细节。 在使用requests发送请求时,可以通过设置headers参数来自定义请求头部信息。一般来说,请求头部信息包含的常见字段有以下几种: 1. User-Agent: User-Agent字段用来表示发送请求的客户端类型和版本信息。有些网站可能会根据User-Agent字段来返回不同的内容,比如PC端和移动端可能返回不同的页面。 2. Referer: Referer字段表示请求的来源页面的URL地址。有些网站可能会根据Referer字段判断请求是否合法,比如防止盗链。 3. Cookie: Cookie字段用来传递请求的会话信息。有些网站会使用Cookie来进行用户身份验证等操作。 除了上述常见的字段,还可以根据具体需要设置其他的自定义字段。例如,可以设置Accept-Encoding字段来指定可以接受的压缩算法,设置Content-Type字段来指定请求体的数据格式,设置Authorization字段来进行身份验证等等。 使用requests库发送请求时,可以通过headers参数入一个字典来设置请求头部信息。例如: ``` import requests headers = { 'User-Agent': 'Mozilla/5.0', 'Referer': 'https://www.example.com', 'Cookie': 'session_id=12345' } response = requests.get(url, headers=headers) ``` 通过设置请求头部信息,我们可以模拟不同的客户端类型和版本,伪装请求的来源,传递会话信息等,以便更好地进行网络数据的获取和交互。 ### 回答2: requests headers是指在使用Pythonrequests发送HTTP请求时,可以在请求添加的一些头部信息。 headers可以用来传递附加的信息给API接口或服务器,使请求更加丰富和具有个性化。常见的headers包括User-Agent、Referer、Authorization等。 User-Agent头部字段可以模拟不同浏览器发送请求,从而绕过某些网站的反爬虫机制,但也需要注意遵守网站的规则,避免给对方造成困扰。 Referer头部字段用于告诉服务器请求的来源页面,有些网站可能会根据Referer信息判断请求是否合法,并做相应处理。 Authorization头部字段用于进行身份验证,如Basic认证、Bearer Token等。这可以保护敏感接口,确保只有经过身份验证的用户才能访问。 除了常见的头部信息外,还可以根据需要添加自定义的headers,传递特定的参数或要求。例如,可以在请求加入Accept-Language字段来指定语言环境,或者添加Cookie字段模拟登陆状态。 在使用requests库发送请求时,可以通过参数`headers`来设置请求头部信息。例如: ```python import requests url = 'https://www.example.com' headers = { 'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/58.0.3029.110 Safari/537.3', 'Referer': 'https://www.example.com', 'Authorization': 'Bearer token123' } response = requests.get(url, headers=headers) ``` 总之,requests headers可以用来在发送HTTP请求时传递附加的头部信息,使请求更加详细和个性化,提供更多定制的功能。 ### 回答3: requests headers是用于HTTP请求的头部信息。HTTP请求头是一些包含信息的字段,它们发送给服务器,用于传递关于请求的额外信息。常见的Headers属性包括: 1. User-Agent:指定客户端的用户代理类型,通常是浏览器名称和版本。此字段可帮助服务器确定如何处理请求。 2. Accept:指定客户端所能接受的内容类型。服务器根据此信息选择合适的响应。 3. Content-Type:指定请求包含的数据的类型。常用的类型有application/json,application/x-www-form-urlencoded等。 4. Authorization:指定请求的授权信息,用于验证客户端身份。 5. Cookie:用于在请求发送之前由服务器设置的cookie信息。 6. Referer:指定发送请求的页面的URL。服务器可以根据这个字段判断请求的来源。 7. Host:指定要请求的服务器域名或IP地址。 8. If-None-Match:在条件请求使用,服务器根据这个字段的值判断资源是否有更新。 通过设置请求头,可以定制HTTP请求的行为,与服务器进行有效的通信。在使用Pythonrequests库时,我们可以通过修改headers属性来添加、修改或删除请求头部信息。例如: ``` import requests headers = { 'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/58.0.3029.110 Safari/537.3', 'Referer': 'http://www.example.com/', } response = requests.get(url, headers=headers) ``` 在上面的示例,我们通过设置User-Agent和Referer字段来定制请求头部信息,以便与服务器进行交互。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值