[英]Why does the requests library add extra headers to the ones I set?
当我设置以下自定义标头时,我尝试使用请求库在python上进行发布请求:
User-Agent: MBAM-C
Content-Type: application/json
Authorization: True
Content-Length: 619
Connection: Close
但是,当它使用自定义标头发送请求时,它会添加自己的标头,从而导致服务器的请求响应不正确。
User-Agent: MBAM-C
Accept-Encoding: gzip, deflate
Accept: */*
Connection: Close
Content-Type: application/json
Authorization: True
Content-Length: 559
这是由于请求项目的设计目标所致。
此行为在此处记录 。 如果该库需要更正内容长度或添加所需的标头,则可能需要使用较低级别的库。 要求帐单本身为:“一个为人类而建的优雅而简单的Python HTTP库。” 广告的一部分是它可以接受压缩内容和所有mime类型。
注意: 自定义标头的优先级低于更具体的信息源 。 例如:
如果在.netrc中指定了凭据,则将覆盖标有headers =的授权标头,而auth =参数将覆盖该标头。 如果您脱离主机重定向,则将删除授权标头。 URL中提供的代理凭证将覆盖Proxy-Authorization标头。 当我们可以确定content的长度时,Content-Length标头将被覆盖 。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.