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

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

2025-06-14 15:36:07作者:蔡怀权

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项目成熟度提升的重要一步。

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

热门内容推荐

项目优选

收起
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
178
262
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
867
513
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
129
183
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
265
305
HarmonyOS-ExamplesHarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
398
371
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
1.07 K
0
ShopXO开源商城ShopXO开源商城
🔥🔥🔥ShopXO企业级免费开源商城系统,可视化DIY拖拽装修、包含PC、H5、多端小程序(微信+支付宝+百度+头条&抖音+QQ+快手)、APP、多仓库、多商户、多门店、IM客服、进销存,遵循MIT开源协议发布、基于ThinkPHP8框架研发
JavaScript
93
15
note-gennote-gen
一款跨平台的 Markdown AI 笔记软件,致力于使用 AI 建立记录和写作的桥梁。
TSX
83
4
cherry-studiocherry-studio
🍒 Cherry Studio 是一款支持多个 LLM 提供商的桌面客户端
TypeScript
598
57
GitNextGitNext
基于可以运行在OpenHarmony的git,提供git客户端操作能力
ArkTS
10
3