Noble TLS 是一个基于 requests 和 tls-client 的高级 HTTP 库。 现在支持异步,提供更多功能并自动更新 JA3 指纹。
pip install noble-tls
requests 的 history 功能requests 的 allow_redirects 功能语法灵感来自 requests,所以非常相似,只有很少的不同之处。
示例 1 - 预设:
import noble_tls from noble_tls import Client # 可用标识符: """ CHROME_103 = "chrome_103" CHROME_104 = "chrome_104" CHROME_105 = "chrome_105" CHROME_106 = "chrome_106" CHROME_107 = "chrome_107" CHROME_108 = "chrome_108" CHROME_109 = "chrome_109" CHROME_110 = "chrome_110" CHROME_111 = "chrome_111" CHROME_112 = "chrome_112" CHROME_116_PSK = "chrome_116_PSK" CHROME_116_PSK_PQ = "chrome_116_PSK_PQ" CHROME_117 = "chrome_117" CHROME_120 = "chrome_120" SAFARI_15_6_1 = "safari_15_6_1" SAFARI_16_0 = "safari_16_0" SAFARI_IPAD_15_6 = "safari_ipad_15_6" SAFARI_IOS_15_5 = "safari_ios_15_5" SAFARI_IOS_15_6 = "safari_ios_15_6" SAFARI_IOS_16_0 = "safari_ios_16_0" FIREFOX_102 = "firefox_102" FIREFOX_104 = "firefox_104" FIREFOX_105 = "firefox_105" FIREFOX_106 = "firefox_106" FIREFOX_108 = "firefox_108" FIREFOX_110 = "firefox_110" FIREFOX_117 = "firefox_117" FIREFOX_120 = "firefox_120" OPERA_89 = "opera_89" OPERA_90 = "opera_90" OPERA_91 = "opera_91" ZALANDO_ANDROID_MOBILE = "zalando_android_mobile" ZALANDO_IOS_MOBILE = "zalando_ios_mobile" NIKE_IOS_MOBILE = "nike_ios_mobile" NIKE_ANDROID_MOBILE = "nike_android_mobile" CLOUDSCRAPER = "cloudscraper" MMS_IOS = "mms_ios" MMS_IOS_1 = "mms_ios_1" MMS_IOS_2 = "mms_ios_2" MMS_IOS_3 = "mms_ios_3" MESH_IOS = "mesh_ios" MESH_IOS_1 = "mesh_ios_1" MESH_IOS_2 = "mesh_ios_2" MESH_ANDROID = "mesh_android" MESH_ANDROID_1 = "mesh_android_1" MESH_ANDROID_2 = "mesh_android_2" CONFIRMED_IOS = "confirmed_ios" CONFIRMED_ANDROID = "confirmed_android" OKHTTP4_ANDROID_7 = "okhttp4_android_7" OKHTTP4_ANDROID_8 = "okhttp4_android_8" OKHTTP4_ANDROID_9 = "okhttp4_android_9" OKHTTP4_ANDROID_10 = "okhttp4_android_10" OKHTTP4_ANDROID_11 = "okhttp4_android_11" OKHTTP4_ANDROID_12 = "okhttp4_android_12" OKHTTP4_ANDROID_13 = "okhttp4_android_13" """ async def main(): await noble_tls.update_if_necessary() # 从 bogdanfinn/tls-client 更新 TLS 客户端库 session = noble_tls.Session( client=Client.CHROME_111, random_tls_extension_order=True ) res = await session.get( "https://www.example.com/", headers={ "key1": "value1", }, proxy="http://user:password@host:port" ) print(res.text)
示例 2 - 自定义:
import noble_tls async def main(): await noble_tls.update_if_necessary() # 从 bogdanfinn/tls-client 更新 TLS 客户端库 session = noble_tls.Session( ja3_string="771,4865-4866-4867-49195-49199-49196-49200-52393-52392-49171-49172-156-157-47-53,0-23-65281-10-11-35-16-5-13-18-51-45-43-27-17513,29-23-24,0", h2_settings={ "HEADER_TABLE_SIZE": 65536, "MAX_CONCURRENT_STREAMS": 1000, "INITIAL_WINDOW_SIZE": 6291456, "MAX_HEADER_LIST_SIZE": 262144 }, h2_settings_order=[ "HEADER_TABLE_SIZE", "MAX_CONCURRENT_STREAMS", "INITIAL_WINDOW_SIZE", "MAX_HEADER_LIST_SIZE" ], supported_signature_algorithms=[ "ECDSAWithP256AndSHA256", "PSSWithSHA256", "PKCS1WithSHA256", "ECDSAWithP384AndSHA384", "PSSWithSHA384", "PKCS1WithSHA384", "PSSWithSHA512", "PKCS1WithSHA512", ], supported_versions=["GREASE", "1.3", "1.2"], key_share_curves=["GREASE", "X25519"], cert_compression_algo="brotli", pseudo_header_order=[ ":method", ":authority", ":scheme", ":path" ], connection_flow=15663105, header_order=[ "accept", "user-agent", "accept-encoding", "accept-language" ] ) res = await session.post( "https://www.example.com/", headers={ "key1": "value1", }, proxy="http://user:password@host:port" ) print(res.text)
如果你想用 Pyinstaller 或 Pyarmor 打包库,请确保在命令中添加以下内容:
Linux - Ubuntu / x86:
--add-binary '{path_to_library}/tls_client/dependencies/tls-client-x86.so:tls_client/dependencies'
Linux Alpine / AMD64:
--add-binary '{path_to_library}/tls_client/dependencies/tls-client-amd64.so:tls_client/dependencies'
MacOS M1 及更早版本:
--add-binary '{path_to_library}/tls_client/dependencies/tls-client-x86.dylib:tls_client/dependencies'
MacOS M2:
--add-binary '{path_to_library}/tls_client/dependencies/tls-client-arm64.dylib:tls_client/dependencies'
Windows:
--add-binary '{path_to_library}/tls_client/dependencies/tls-client-64.dll;tls_client/dependencies'
包的名称来源于《月球叛军:第一部 - 火之子》中的反派 Atticus Noble 将军
非常感谢 Bogdanfinn 开源他的 Golang 版 tls-client。 以及 FlorianREGAZ


AI一键生成PPT,就用博思AIPPT!
博思AIPPT,新一代的AI生成PPT平台,支持智能生成PPT、AI美化PPT、文本&链接生成PPT、导入Word/PDF/Markdown文档生成PPT等,内置海量精美PPT模板,涵盖商务、教育、科技等不同风格,同时针对每个页面提供多种版式,一键自适应切换,完美适配各种办公 场景。


AI赋能电商视觉革命,一站式智能商拍平台
潮际好麦深耕服装行业,是国内AI试衣效果最好的软件。使用先进AIGC能力为电商卖家批量提供优质的、低成本的商拍图。合作品牌有Shein、Lazada、安踏、百丽等65个国内外头部品牌,以及国内10万+淘宝、天猫、京东等主流平台的品牌商家,为卖家节省将近85%的出图成本,提升约3倍出图效率,让品牌能够快速上架。


企业专属的AI法律顾问
iTerms是法大大集团旗下法律子品牌,基于最先进的大语言模型(LLM)、专业的法律知识库和强大的智能体架构,帮助企业扫清合规障碍,筑牢风控防线,成为您企业专属的AI法律顾问。


稳定高效的流量提升解决方案,助力品牌曝光
稳定高效的流量提升解决方案,助力品牌曝光


最新版Sora2模型免费使用,一键生成无水印视频
最新版Sora2模型免费使用,一键生成无水印视频


实时语音翻译/同声传译工具
Transly是一个多场景的AI大语言模型驱动的同声传译、专业翻译助手,它拥有超精准的音频识别翻译能力,几乎零延迟的使用体验和支持多国语言可以让你带它走遍全球,无论你是留学生、商务人士、韩剧美剧爱好者,还是出国游玩、多国会议、跨国追星等等,都可以满足你所有需要同传的场景需求,线上线下通用,扫除语言障碍 ,让全世界的语言交流不再有国界。


选题、配图、成文,一站式创作,让内容运营更高效
讯飞绘文,一个AI集成平台,支持写作、选题、配图、排版和发布。高效生成适用于各类媒体的定制内容,加速品牌传播,提升内容营销效果。


AI辅助编程,代码自动修复
Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。


最强AI数据分析助手
小浣熊家族Raccoon,您的AI智能助手,致力于通过先进的人工智能技术,为用户提供高效、便捷的智能服务。无论是日常咨询还是专业问题解答,小浣熊都能以快速、准确的响应满足您的需求,让您的生活更加智能便捷。


像人一样思考的AI智能体
imini 是一款超级AI智能体,能根据人类指令,自主思考、自主完成、并且交付结果的AI智能体。
最新AI工具、AI资讯
独家AI资源、AI项目落地

微信扫一扫关注公众号