首页
/ curl_cffi v0.11.2版本发布:HTTP客户端库的重要更新

curl_cffi v0.11.2版本发布:HTTP客户端库的重要更新

2025-06-14 04:55:17作者:蔡怀权

curl_cffi是一个基于cURL和Python CFFI的高性能HTTP客户端库,它提供了与requests类似的API接口,但具有更好的性能和更底层的控制能力。该项目特别适合需要模拟浏览器行为或处理复杂HTTP场景的开发需求。

版本核心变更解析

Cookie处理机制优化

本次v0.11.2版本引入了一个重要的行为变更:response.cookies对象现在仅包含当前请求中的cookie,而不再自动包含重定向过程中的所有cookie。这一变更使得cookie处理更加明确和符合直觉。

对于需要跟踪整个会话cookie的场景,开发者现在必须显式使用Session对象:

import curl_cffi
# 不推荐的方式(可能丢失重定向过程中的cookie)
r = curl_cffi.get("https://example.com/redirect")
print(r.cookies)  # 仅显示最后一次请求的cookie

# 推荐的方式(完整跟踪会话cookie)
s = curl_cffi.Session()
r = s.get("https://example.com/redirect") 
print(s.cookies)  # 显示整个会话过程中的所有cookie

这一变更虽然带来了轻微的破坏性变化,但提高了API的明确性和一致性,避免了之前版本中可能出现的隐式行为导致的bug。

新功能与改进

HTTP版本字符串支持

现在开发者可以使用字符串形式设置HTTP版本,提高了代码的可读性:

# 之前只能使用数字常量
r = curl_cffi.get("https://example.com", http_version=2)

# 现在可以使用字符串
r = curl_cffi.get("https://example.com", http_version="2")

支持的有效字符串值包括:"1.0"、"1.1"、"2"、"3"等,对应不同的HTTP协议版本。

重定向URL编码处理

增强了对重定向Location头部的编码处理能力,当遇到无法解码的URL时,现在会优雅地回退到latin-1编码,避免了之前版本中可能出现的解码错误。

Firefox特有扩展控制

新增了对Firefox特有HTTP扩展的开关控制,开发者可以根据需要启用或禁用这些扩展:

# 禁用Firefox特有扩展
curl_cffi.get("https://example.com", firefox_extensions=False)

这一功能特别适合需要精确控制HTTP头部的场景。

Cookie存储禁用选项

现在可以通过use_cookie_store=False参数完全禁用cookie存储功能:

# 完全禁用cookie存储
curl_cffi.get("https://example.com", use_cookie_store=False)

这对于不需要cookie功能或需要手动管理cookie的场景非常有用。

技术实现细节

在底层实现上,curl_cffi v0.11.2继续优化了与libcurl的交互效率。通过CFFI接口,Python代码能够直接调用libcurl的高性能网络功能,同时保持了Pythonic的API设计。

对于cookie处理的变化,底层实际上是调整了CURLOPT_COOKIELIST和CURLOPT_COOKIEJAR等选项的行为,使得每个请求的cookie处理更加隔离和明确。

升级建议

对于现有项目,升级到v0.11.2版本时需要注意:

  1. 检查所有依赖response.cookies的代码,确保它们不隐式依赖重定向过程中的cookie
  2. 对于需要完整cookie跟踪的场景,改用Session对象
  3. 考虑使用新的字符串形式HTTP版本设置,提高代码可读性
  4. 评估是否需要禁用Firefox扩展或cookie存储功能

这个版本在保持API简洁性的同时,提供了更精细的控制能力,是curl_cffi项目成熟度提升的重要一步。

登录后查看全文
热门项目推荐
相关项目推荐

热门内容推荐

最新内容推荐

项目优选

收起
kernelkernel
deepin linux kernel
C
22
6
docsdocs
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
154
1.98 K
ops-mathops-math
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
506
42
nop-entropynop-entropy
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
8
0
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
194
279
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
992
395
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
940
554
communitycommunity
本项目是CANN开源社区的核心管理仓库,包含社区的治理章程、治理组织、通用操作指引及流程规范等基础信息
335
11
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
146
191
金融AI编程实战金融AI编程实战
为非计算机科班出身 (例如财经类高校金融学院) 同学量身定制,新手友好,让学生以亲身实践开源开发的方式,学会使用计算机自动化自己的科研/创新工作。案例以量化投资为主线,涉及 Bash、Python、SQL、BI、AI 等全技术栈,培养面向未来的数智化人才 (如数据工程师、数据分析师、数据科学家、数据决策者、量化投资人)。
Python
75
70