前言

要将自己的 cookie 发送到服务器,可以使用构造函数的cookies 参数ClientSession

自定义cookie

cookie 定义成字典键值对格式,传参到ClientSession

url = 'http://httpbin.org/cookies'
cookies = {'cookies_are': 'working'}
async with ClientSession(cookies=cookies) as session:
async with session.get(url) as resp:
assert await resp.json() == {
"cookies": {"cookies_are": "working"}}

笔记


httpbin.org/cookies端点以 JSON 编码的正文返回请求 cookie。要访问会话 cookie,请参阅ClientSession.cookie_jar。


ClientSession可用于在多个请求之间共享 cookie:

async with aiohttp.ClientSession() as session:
await session.get(
'http://httpbin.org/cookies/set?my_cookie=my_value')
filtered = session.cookie_jar.filter_cookies(
'http://httpbin.org')
assert filtered['my_cookie'].value == 'my_value'
async with session.get('http://httpbin.org/cookies') as r:
json_body = await r.json()
assert json_body['cookies']['my_cookie'] == 'my_value'

使用实例

以登录禅道网站为例,当我们第一次登录了禅道网站,浏览器关闭后,重新打开首页(非登录页),不需要再走登录流程。

像这种网站会记住登陆的cookies,并且在一段时间内都会有效(具体有效时长每个网站的失效时间不一样)

如果不想登录,可以打开登录之后的任意页面,找到请求标头里面的cookies这一栏,找到跟登录相关的cookie(需靠自己的经验了)。

zentaosid=6f8d76hvd1ugqip86ptolb0lm1

aiohttp 异步http请求-10.ClientSession自定义请求Cookie_aiohttp

把cookie 写成字典格式键值对,多个cookie也可以

cookies = {
"zentaosid": "2g5co7cgos0snikh0td9s4sha0"
}

完整的代码

import aiohttp
import asyncio


async def task(session):
async with session.get(url='/zentao/my/') as resp:
print(resp.status)
res = await resp.text()
print(res)


async def main():
cookies = {
"zentaosid": "2g5co7cgos0snikh0td9s4sha0"
}
base_url = "http://127.0.0.1:8000"
async with aiohttp.ClientSession(
base_url=base_url, cookies=cookies) as session:
await task(session)


loop = asyncio.get_event_loop()
loop.run_until_complete(main())

运行结果

200
<!DOCTYPE html>
<html lang='zh-cn'>
<head>
<meta charset='utf-8'>
<meta http-equiv='X-UA-Compatible' content='IE=edge'>
<meta name="viewport" content="width=device-width, initial-scale=1">
<meta name="renderer" content="webkit">
<title>我的地盘 - 禅道</title>

从运行打印结果可以看到,是登录成功的页面。

ClientSession可用于在多个请求之间共享 cookie, 这就意味着只需在ClientSession传一次cookie,就可以在session会话里面访问当前网站的多个请求了。

获取session会话cookie

使用​​session.cookie_jar​​ 获取session对象的cookies

  • session.cookie_jar 返回一个可迭代对象
  • len(session.cookie_jar) 获取cookie的个数
  • cookie.key 获取cookie的key值
  • cookie.value 获取cookie的value值
  • cookie["domain"] 获取域名
async def main():
cookies = {
"zentaosid": "2g5co7cgos0snikh0td9s4sha0"
}
base_url = "http://127.0.0.1:8000"
async with aiohttp.ClientSession(
base_url=base_url, cookies=cookies) as session:
print(session.cookie_jar)
print(len(session.cookie_jar))
for cookie in session.cookie_jar:
print(cookie)
print(cookie.key)
print(cookie.value)
print(cookie["domain"])
await task(session)

运行结果

<aiohttp.cookiejar.CookieJar object at 0x000001E2C0D0ED90>
1
Set-Cookie: zentaosid=2g5co7cgos0snikh0td9s4sha0; Path=/
zentaosid
2g5co7cgos0snikh0td9s4sha0

cookie_jar 里面还有几个常用的操作方法

  • filter_cookies ( request_url ) 返回 URL 可接受的 jar cookie 并在 Cookie标头中可用于发送给定 URL 的客户端请求。参数response_url(str) – 请求 cookie 的请求 URL。
  • update_cookies ( cookies , response_url = None ) 更新服务器在标头中返回的 cookie Set-Cookie
  • clear(predicate=None) 为None,则从jar中移除所有cookie。否则,只删除predicate(morsel)返回 True的.
  • clear_domain(domain) 从 jar 中删除属于指定域或其子域的所有 cookie。

session会话更新cookie

ClientSession可用于在多个请求之间共享 cookie,我们可以在创建session会话的时候把cookie参数传进去

cookies = {
"zentaosid": "2g5co7cgos0snikh0td9s4sha0"
}
base_url = "http://127.0.0.1:8000"
async with aiohttp.ClientSession(
base_url=base_url, cookies=cookies) as session:

也可以在创建完会话,在session 对象上更新

cookies = {
"zentaosid": "2g5co7cgos0snikh0td9s4sha0"
}
session.cookie_jar.update_cookies()