Client¶
Authlib provides OAuth 2.0 client implementations for two distinct use cases:
HTTP Clients — your Python code fetches tokens and calls APIs directly. Suitable for scripts, CLIs, service-to-service communication:
from authlib.integrations.requests_client import OAuth2Session
client = OAuth2Session(client_id, client_secret)
token = client.fetch_token(token_endpoint, ...)
resp = client.get('https://api.example.com/data')
Web Clients — your web application delegates authentication to an OAuth 2.0 provider. Works with any provider: well-known services (GitHub, Google…) or your own authorization server. Integrations for Flask, Django, Starlette and FastAPI:
from authlib.integrations.flask_client import OAuth
oauth = OAuth(app)
github = oauth.register('github', {...})
@app.route('/login')
def login():
return github.authorize_redirect(url_for('authorize', _external=True))