异步web请求,无法正确进行身份验证



我一直在尝试编程一个e621抓取器,尽管我想以异步方式进行,但这似乎无法使身份验证工作

当它返回"0"时;resp";它不返回任何内容,因为auth是错误的。我知道细节是正确的,但我不确定如何在异步编程中做到这一点。感谢您的帮助!非常感谢。

async def main():
async with aiohttp.ClientSession() as session:
url = 'https://e621.net/posts.json?limit=2&'
params = {'user-agent':'frbottest/0.0.1 (by Vaston on e621)'}
async with session.get(url, params=params, auth=aiohttp.BasicAuth(apiUser, apiKey)) as resp:
resp = await resp.json(content_type=None)
content = await resp.json()
print(content['url'])

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

事实证明,e621要求您将头放入请求中才能正确授权。不需要使用authparams组件,您只是在session的定义中缺少了一个头字典。请参阅此处(只需将代理和密钥占位符替换为apiUserapiKey值(:

import asyncio
import aiohttp
import json
headers = {
'User-Agent': '<my_agent>',
'Authorization': 'Basic <my_key>'
}
async def main():
async with aiohttp.ClientSession(headers=headers) as session:
url = 'https://e621.net/posts.json?limit=2&'
async with session.get(url) as resp:
resp = await resp.json(content_type=None)
print(json.dumps(resp.get('posts')[0], indent=2))
loop = asyncio.get_event_loop()
loop.run_until_complete(main())

最新更新