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数字人视频创作平台
Keevx 一款开箱即用的AI数字人视频创作平台,广泛适用于电商广告、企业培训与社媒宣传,让全球企业与个人创作者无需拍摄剪辑,就能快速生成多语言、高质量的专业视频。
一站式AI创作平台
提供 AI 驱动的图片、视频生成及数字人等功能,助力创意创作
AI办公助手,复杂任务高效处理
AI办公助手,复杂任务高效处理。办公效率低?扣子空间AI助手支持播客生成、PPT制作、网页开发及报告写作,覆盖科研、商业、舆情等领域的专家Agent 7x24小时响应,生活工作无缝切换,提升50%效率!
AI辅助编程,代码自动修复
Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。
AI小说写作助手,一站式润色、改写、扩写
蛙蛙写作—国内先进的AI写作平台,涵盖小说、学术、社交媒体等多场景。 提供续写、改写、润色等功能,助力创作者高效优化写作流程。界面简洁,功能全面,适合各类写作者提升内容品质和工作效率。
全能AI智能助手,随时解答生活与工作 的多样问题
问小白,由元石科技研发的AI智能助手,快速准确地解答各种生活和工作问题,包括但不限于搜索、规划和社交互动,帮助用户在日常生活中提高效率,轻松管理个人事务。
实时语音翻译/同声传译工具
Transly是一个多场景的AI大语言模型驱动的同声传译、专业翻译助手,它拥有超 精准的音频识别翻译能力,几乎零延迟的使用体验和支持多国语言可以让你带它走遍全球,无论你是留学生、商务人士、韩剧美剧爱好者,还是出国游玩、多国会议、跨国追星等等,都可以满足你所有需要同传的场景需求,线上线下通用,扫除语言障碍,让全世界的语言交流不再有国界。
一键生成PPT和Word,让学习生活更轻松
讯飞智文是一个利用 AI 技术的项目,能够帮助用户生成 PPT 以及各类文档。无论是商业领域的市场分析报告、年度目标制定,还是学生群体的职业生涯规划、实习避坑指南,亦或是活动策划、旅游攻略等内容,它都能提供支持,帮助用户精准表达,轻松呈现各种信息。
深度推理能力全新升级,全面对标OpenAI o1
科大讯飞的星火大模型,支 持语言理解、知识问答和文本创作等多功能,适用于多种文件和业务场景,提升办公和日常生活的效率。讯飞星火是一个提供丰富智能服务的平台,涵盖科技资讯、图像创作、写作辅助、编程解答、科研文献解读等功能,能为不同需求的用户提供便捷高效的帮助,助力用户轻松获取信息、解决问题,满足多样化使用场景。
一种基于大语言模型的高效单流解耦语音令牌文本到语音合成模型
Spark-TTS 是一个基于 PyTorch 的开源文本到语音合成项目,由多个知名机构联合参与。该项目提供了高效的 LLM(大语言模型)驱动的语音合成方案,支持语音克隆和语音创建功能,可通过命令行界面(CLI)和 Web UI 两种方式使用。用户可以根据需求调整语音的性别、音高、速度等参数,生成高质量的语音。该项目适用于多种场景,如有声读物制作、智能语音助手开发等。
最新AI工具、AI资讯
独家AI资源、AI项目落地
微信扫一扫关注公众号