python使用TLS1.2协议请求

本文介绍了在Python中处理某些网站请求时遇到的403错误,并提供了使用urllib、requests和scrapy库强制使用TLSv1.2的解决方案。通过自定义SSL上下文和适配器,确保了请求的顺利进行。此外,还展示了如何在httpx库中配置TLS版本。
摘要由CSDN通过智能技术生成

针对部分网站使用python请求出现403等,强制使用tls1.2发包的场景
如某盛优选小程序,fiddler重新发包正常,用程序请求失败

1.urllib版本

context = ssl.SSLContext(ssl.PROTOCOL_TLSv1_2)
response = urllib.request.urlopen(url=urllib.request.Request(url=url, headers=headers),
                                  data=data, context=context)
response = response.read().decode()
print(response)

2.requests版本

import ssl
import requests
from requests.adapters import HTTPAdapter, PoolManager
class MyAdapter(HTTPAdapter):
	# 重写init_poolmanager方法
    def init_poolmanager(self, connections, maxsize, block=False, **pool_kwargs):
        self.poolmanager = PoolManager(num_pools=connections,
                                       maxsize=maxsize,
                                       block=block,
                                       ssl_version=ssl.PROTOCOL_TLSv1_2)

s = requests.Session()
s.mount('https://', MyAdapter())
res = s.post(url, data=data, headers=headers)
text = res.text

3.在scrapy中强制使用TLS1.2的话需要在settings.py中设置以下代码

参考scrapy文档: https://docs.scrapy.org/en/latest/topics/settings.html#std-setting-DOWNLOADER_CLIENT_TLS_CIPHERS

DOWNLOADER_CLIENT_TLS_METHOD="TLSv1.2"

4.直接使用httpx请求

import httpx
res = httpx.post(url, data=data, headers=headers)
text = res.text
  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值