当前位置: 首页 > wzjs >正文

腾讯云 建网站网站建设及政务公开工作总结

腾讯云 建网站,网站建设及政务公开工作总结,网站建设可以买东西,python基础教程答案什么是HTTPX? HTTPX 是一个功能齐全的Python HTTP客户端库,支持同步和异步API,基于标准库的 http 包构建。它是 requests 库的现代替代品,添加了对HTTP/2、连接池和异步请求等功能的原生支持。 主要特性 同步和异步API&#xf…

什么是HTTPX?

HTTPX 是一个功能齐全的Python HTTP客户端库,支持同步和异步API,基于标准库的 http 包构建。它是 requests 库的现代替代品,添加了对HTTP/2、连接池和异步请求等功能的原生支持。

主要特性

  1. 同步和异步API:支持 requests 风格的同步API和 asyncio 驱动的异步API
  2. HTTP/2支持:通过 http2=True 参数启用
  3. 类型注解:完整的类型提示,提升开发体验
  4. 超时处理:细粒度的超时控制
  5. 连接池:自动管理连接池,提高性能
  6. WebSocket支持:内置WebSocket客户端
  7. 代理支持:HTTP/HTTPS/SOCKS代理
  8. 文件上传:支持多部分文件上传

安装

pip install httpx

如果需要HTTP/2支持:

pip install 'httpx[http2]'

基础用法

同步请求

import httpx# GET请求
response = httpx.get('https://httpbin.org/get')
print(response.status_code)
print(response.json())# 带参数的GET
params = {'key1': 'value1', 'key2': 'value2'}
response = httpx.get('https://httpbin.org/get', params=params)# POST请求
data = {'key': 'value'}
response = httpx.post('https://httpbin.org/post', json=data)

异步请求

import asyncio
import httpxasync def fetch_data():async with httpx.AsyncClient() as client:response = await client.get('https://httpbin.org/get')return response.json()# 运行异步函数
result = asyncio.run(fetch_data())
print(result)

高级特性

1. 客户端实例

使用 ClientAsyncClient 可以复用连接,提高性能:

# 同步
with httpx.Client() as client:response = client.get('https://httpbin.org/get')# 异步
async with httpx.AsyncClient() as client:response = await client.get('https://httpbin.org/get')

2. 超时设置

# 全局超时
timeout = httpx.Timeout(10.0, connect=5.0)  # 10秒总超时,5秒连接超时# 每个请求单独设置
response = httpx.get('https://httpbin.org/delay/5', timeout=timeout)# 或者直接设置秒数
response = httpx.get('https://httpbin.org/delay/5', timeout=10.0)

3. 自定义请求头

headers = {'User-Agent': 'MyApp/1.0','Authorization': 'Bearer token123'
}
response = httpx.get('https://httpbin.org/headers', headers=headers)

4. 处理响应

response = httpx.get('https://httpbin.org/get')# 状态码
print(response.status_code)# 响应头
print(response.headers)
# 响应体文本
print(response.text)
# JSON响应
print(response.json())
# 二进制响应
print(response.content)
# 流式响应
with httpx.stream("GET", "https://www.example.com") as response:for chunk in response.iter_bytes():print(chunk)

5. 文件上传

# 单个文件
files = {'file': open('report.xls', 'rb')}
response = httpx.post('https://httpbin.org/post', files=files)# 多个文件
files = [('images', ('image1.jpg', open('image1.jpg', 'rb'), 'image/jpeg')),('images', ('image2.jpg', open('image2.jpg', 'rb'), 'image/jpeg'))
]
response = httpx.post('https://httpbin.org/post', files=files)

6. 代理支持

proxies = {"http://": "http://localhost:8030","https://": "http://localhost:8031",
}response = httpx.get("http://example.com", proxies=proxies)

7. 重试机制

from httpx import HTTPStatusError, TimeoutExceptiondef log_retry(request, exc):print(f"Request {request.url} failed: {exc}")client = httpx.Client(event_hooks={"request": [log_retry],},transport=httpx.HTTPTransport(retries=3)  # 重试3次
)try:response = client.get("https://example.com")response.raise_for_status()
except (HTTPStatusError, TimeoutException) as exc:print(f"Request failed after retries: {exc}")

与Requests的主要区别

  1. 异步支持httpx 原生支持 async/await
  2. HTTP/2httpx 支持 HTTP/2,而 requests 不支持
  3. 类型提示httpx 有完整的类型注解
  4. 性能httpx 在某些情况下可能更高效,特别是在处理大量并发请求时
  5. API兼容性httpx 的API设计类似于 requests,但不完全相同

最佳实践

  1. 使用上下文管理器:确保资源被正确释放

    with httpx.Client() as client:response = client.get('https://example.com')
    
  2. 复用客户端:为多个请求创建单个客户端实例

    # 不好
    def get_data():return httpx.get('https://api.example.com/data')# 好
    client = httpx.Client()
    def get_data():return client.get('https://api.example.com/data')
    
  3. 处理异常

    try:response = httpx.get('https://example.com')response.raise_for_status()
    except httpx.HTTPStatusError as exc:print(f"Error response {exc.response.status_code}")
    except httpx.RequestError as exc:print(f"Request failed: {exc}")
    
  4. 设置超时:总是设置合理的超时

    response = httpx.get('https://example.com', timeout=10.0)
    
  5. 使用连接池:默认启用,但可以调整大小

    limits = httpx.Limits(max_keepalive_connections=5, max_connections=10)
    client = httpx.Client(limits=limits)
    

性能考虑

  1. 连接池httpx 默认使用连接池,提高性能
  2. HTTP/2:对于多个请求到同一主机,HTTP/2 可以显著提高性能
  3. 流式响应:对于大文件,使用流式响应减少内存使用
    with httpx.stream("GET", "https://example.com/large_file") as response:with open("large_file", "wb") as f:for chunk in response.iter_bytes():f.write(chunk)
    

常见问题

1. 如何禁用SSL验证?

client = httpx.Client(verify=False)  # 不推荐用于生产环境

2. 如何设置基本认证?

auth = ('username', 'password')
response = httpx.get('https://example.com', auth=auth)

3. 如何发送表单数据?

data = {'key1': 'value1', 'key2': 'value2'}
response = httpx.post('https://httpbin.org/post', data=data)

4. 如何处理cookies?

# 发送cookies
cookies = {"session_id": "abc123"}
response = httpx.get('https://example.com', cookies=cookies)# 获取cookies
print(response.cookies['session_id'])

总结

HTTPX 是一个功能强大、现代化的HTTP客户端,适合从简单到复杂的HTTP请求场景。它结合了 requests 的易用性和现代Python特性,是构建HTTP客户端的绝佳选择。

对于新项目,特别是需要异步支持或HTTP/2的项目,强烈建议考虑使用HTTPX而不是较老的 requests 库。

http://www.dtcms.com/wzjs/807323.html

相关文章:

  • wordpress建站文本教程一般企业邮箱是哪里注册
  • site网站连通率0%怎么解决站长工具海角
  • 做网站页面报价短视频seo排名系统
  • 怎样成立网站网站中的冒号
  • 做产品类网站菏泽网站建设 梧桐树
  • 没有公司做网站wordpress admin-ajax.php 漏洞
  • 如何做国外网站河北高阳做网站的
  • 科技股份公司网站模板云南昆明网站建设公司
  • 用dw做网站流程wordpress 教程 mysql
  • 做交通招聘的网站自己设计图纸的软件
  • 怎么编辑自己的网站wordpress分类权限
  • 天津实用网站建设平台柳州房地产网站建设
  • 机械设备如何做网站做英文网站賺钱
  • 网站制作什么品牌好西安建站公司模板
  • 网站备案服务内容灌南县规划局网站理想家园规划建设
  • 兰州西固区公司网站建设百度站长管理平台
  • 建设网站的方案贴吧 wordpress
  • 免费网站制作新闻wordpress手机分享插件
  • 百度改网站描述东莞专业网站建设公司
  • iis打开网站变成下载唐山网站排名提升
  • 黑龙江网站设计蓬莱做网站那家好
  • 做网站需要的导航手机与pc的网站开发
  • wordpress博客站模板外贸网络推广是什么
  • php wap网站源码wordpress首页怎么美化
  • 小米手机如何做游戏视频网站夺宝网站还可以做吗
  • 商城网站开发报价wordpress官网案例
  • 北京网站建设亿玛酷出名5项目外包平台接活
  • 网站优化建设兰州做搜狗pc网站优化
  • 中国建设银行数据管理部网站wordpress设置静态之后文章打不开
  • 如何选择郑州网站建设做物流网站有哪些内容