aiohttp-client的基本使用

  1. aiohttp介绍
  • 一个用于asyncio和python的异步http客户端/服务端
  • 支持客户端和http服务器
  • 在没有回调地狱的情况下支持服务器websockers和客户端websocket开箱即用
  • web服务器具有中间件,信号和可插拔路由

  1. 安装
  • pip3 install aiohttp
  • pip3 install cchardet 可选库
  • pip3 install aiodns 加快客户端api的dns解析

  1. 发送一个http请求
import asyncio
import aiohttp

async with aiohttp.ClientSession() as session:
    async with session.get('http://httpbin.org/get') as resp:
        print(resp.status)
        print(await resp.text())
  • 解释:在这使用了一个ClientSession的实例session调用了ClientResponse对象的resp实例,我们可以从resp这个实例中获取所有的信息
session.post('http://httpbin.org/post', data=b'data')
session.put('http://httpbin.org/put', data=b'data')
session.delete('http://httpbin.org/delete')
session.head('http://httpbin.org/head')
session.options('http://httpbin.org/options')
  • Note:不要为每个请求单独创建一个会话,很可能每个应用程序都只需要一个会话来完成所有的请求
  • 会话上下文管理器的使用并不是强制性的,但是不用会话上下文管理器创建会话时应该调用await session.close(),手动关闭会话
import asyncio
import aiohttp

session = aiohttp.ClientSession()

async with session.get(''):
    ...
await session.close()

  1. 在url中传递参数
  • 如果希望在url中传递一些参数,可以构建一个字典用于存放参数的键跟值,然后传递给get方法的params关键字参数
params = {'key1':'value1', 'key2': 'value2'}
async with session.get('http://httpbin.org', params=params) as resp:
    print(resp.url)
  • 相应内容和状态码
import asyncio
import aiohttp

async with session.get(url) as resp:
    print(resp.status) # http状态码
    print(await resp.text()) # 响应内容
  • Note:可以在text()方法中指定自定义的编码
    await resp.text(encoding='gb2312')

  • 二进制响应内容
  • 对于非文本请求,可以以字节为单位访问响应正文
    print(await resp.read())

  • 所有的会话的请求方法,如request(),ClientSession.get(), ClientSession.post()等接受json参数
async with aiohttp.ClientSession() as session:
    async with session.post(url, json={"test": "object"})

Note: 默认情况下,session使用python的标准库json模块进行序列化。但是可以使用不同的serializer。ClientSession接受json_serialize参数

import ujson
async with aiohttp.ClientSession(json_serializse=ujson.dumps) as session:
    await session.post(url, json={"txt": "ojk"})

Note: ujson库比标准库中的json库更快但是稍微不兼容


  • json响应内容
  • 如果需要处理json数据,session内置了一个json解释吗器
async with session.get(url) as resp:
    print(await resp.json())

Note:如果json解码失败将引发异常,可以为json()的调用指定自定义的编码和解码功能


  • 超时
  • 超时设置存储在ClientTimeout数据结构中。
  • 默认情况下,aiohttp使用total5分钟超时,这意味的整个操作应该在5分钟内完成
  • 该值可以被session的超时参数覆盖
timeout = aiohttp.ClientTimeout(total=60)
async with aiohttp.ClientSession(timeout=timeout) as session:
    ...
  • ClientTimeout支持的字段有以下
  • total:整个操作时间包括连接的建立,请求的发送和响应
  • sock_connect:时间包括建立的新连接,或者如果超出连接池限制,则等待池中的空闲连接
  • sock_read:从等待方读取新数据部分之间的最大允许超时时间
  • Note:所有字段都是浮点数,None或者0禁用特定的超时检查
aiohttp.ClientTimeout(total=5*60, connect=None, sock_connect=None, sock_read=None)

that's all
ps:后续补上高级使用

你可能感兴趣的:(aiohttp-client的基本使用)