curl_cffi v0.11.0发布:全面支持HTTP/3协议
curl_cffi是一个基于cURL库的Python绑定项目,它提供了对cURL功能的完整访问,特别适合需要模拟浏览器行为的网络请求场景。该项目通过FFI(外部函数接口)技术实现了对cURL底层API的直接调用,同时提供了简洁的Python接口,使得开发者能够轻松实现复杂的HTTP请求操作。
HTTP/3协议支持
本次发布的v0.11.0版本最显著的改进是增加了对HTTP/3协议的支持(Windows平台除外)。HTTP/3是基于QUIC协议的新一代HTTP协议,相比HTTP/2和HTTP/1.1,它在连接建立速度、多路复用和连接迁移等方面都有显著优势。
开发者现在可以通过简单的API调用来使用HTTP/3协议:
import curl_cffi
from curl_cffi import CurlHttpVersion
r = curl_cffi.get("https://example-quic.com", http_version=CurlHttpVersion.V3ONLY)
print(r.status_code) # 输出: 200
print(r.http_version == CurlHttpVersion.V3) # 输出: True
该功能使得curl_cffi能够访问越来越多的支持HTTP/3的网站,特别是那些已经开始部署QUIC协议的现代Web服务。
新增浏览器模拟目标
v0.11.0版本还新增了多个浏览器模拟目标,包括:
- browser145 (匿名浏览器)
- safari184 (Safari桌面版)
- safari184_ios (iOS版Safari)
- chrome136 (Chrome浏览器)
这些新增的模拟目标使得开发者能够更精确地模拟不同浏览器环境下的请求行为,对于需要绕过反爬机制或测试网站兼容性的场景特别有用。
其他重要改进
-
DEBUGFUNCTION支持:完整实现了cURL的调试回调功能,开发者现在可以获取更详细的请求调试信息。
-
请求头编码优先级:修复了请求头编码处理逻辑,现在明确请求级别的编码设置会覆盖会话级别的设置。
-
CURL_IPRESOLVE枚举:新增了对IP解析策略的支持,开发者可以指定使用IPv4或IPv6协议。
-
curl_easy_upkeep支持:实现了对HTTP/2和HTTP/3连接维护的支持,有助于保持长连接的有效性。
-
新增加密套件:补充了更多现代加密算法的支持,提升了安全性。
-
多请求接口增强:扩展了curl_multi_*系列函数的支持,为高级并发请求场景提供了更多控制选项。
技术实现细节
在底层实现上,v0.11.0版本通过集成最新的cURL库和nghttp3/quiche等HTTP/3实现库,构建了一个完整的HTTP/3支持栈。项目维护了与Python ctypes的高效交互,确保在提供丰富功能的同时保持高性能。
对于希望在Python项目中使用现代HTTP协议特性的开发者来说,curl_cffi v0.11.0提供了一个强大而灵活的工具集。它不仅支持最新的HTTP/3协议,还通过不断完善的浏览器模拟功能,满足了各种复杂的网络请求需求。
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust099- DDeepSeek-V4-ProDeepSeek-V4-Pro(总参数 1.6 万亿,激活 49B)面向复杂推理和高级编程任务,在代码竞赛、数学推理、Agent 工作流等场景表现优异,性能接近国际前沿闭源模型。Python00
MiMo-V2.5-ProMiMo-V2.5-Pro作为旗舰模型,擅⻓处理复杂Agent任务,单次任务可完成近千次⼯具调⽤与⼗余轮上 下⽂压缩。Python00
GLM-5.1GLM-5.1是智谱迄今最智能的旗舰模型,也是目前全球最强的开源模型。GLM-5.1大大提高了代码能力,在完成长程任务方面提升尤为显著。和此前分钟级交互的模型不同,它能够在一次任务中独立、持续工作超过8小时,期间自主规划、执行、自我进化,最终交付完整的工程级成果。Jinja00
Kimi-K2.6Kimi K2.6 是一款开源的原生多模态智能体模型,在长程编码、编码驱动设计、主动自主执行以及群体任务编排等实用能力方面实现了显著提升。Python00
MiniMax-M2.7MiniMax-M2.7 是我们首个深度参与自身进化过程的模型。M2.7 具备构建复杂智能体应用框架的能力,能够借助智能体团队、复杂技能以及动态工具搜索,完成高度精细的生产力任务。Python00