Django OAuth-在中间件中包含授权标头?

时间:2020-05-18 14:00:08

标签: python django authentication oauth django-oauth

我成功配置了django-oauth-toolkit。我想在从OAuth提供商收到访问令牌后授权第三方用户。将其保存在Django Admin中后,我可以使用它来访问受限制的网站:

curl -H "Authorization: Bearer 123456" -X GET http://localhost:8000/secret/

我想象的体系结构是有一个登录页面,我可以在其中使用Django Sessions将Authorization令牌存储在标头中。但是,当我尝试在中间件中设置Authorization标头时,它并不允许我访问该站点。我在访问该网站时检查了响应,但看起来根本没有保存标题。我尝试使用下面的代码。

class OAuthDt:
    def __init__(self, get_response):
        self.get_response = get_response

    def __call__(self, request):
        def process_request(request):
            request.META['Authorization'] = "Bearer 123456"
            return(request)
        request.Authorization = "Bearer 123456"
        request = process_request(request)
        response = self.get_response(request)
        return(response) 

Views.py

@login_required()
def secret_page(request, *args, **kwargs):
    return HttpResponse('Secret contents!', status=200)

所以我的猜测是:

  1. 在我看来,身份验证检查是在中间件保存标头之前完成的。
  2. 有些原因使我无法更新请求标头或覆盖标头。也许是另一个中间件

检查服务器日志后,我更倾向于2号。

[18/May/2020 13:54:38] "GET /secret/ HTTP/1.1" 302 0
This executes before redirecting user
Not Found: /accounts/login/
[18/May/2020 13:54:38] "GET /accounts/login/?next=/secret/ HTTP/1.1" 404 2362

这是我的中间件的顺序:

MIDDLEWARE = [
    'corsheaders.middleware.CorsMiddleware',
    'django.middleware.security.SecurityMiddleware',
    'django.contrib.sessions.middleware.SessionMiddleware',
    'django.middleware.common.CommonMiddleware',
    'django.middleware.csrf.CsrfViewMiddleware',
    'django.contrib.auth.middleware.AuthenticationMiddleware',
    'django.contrib.messages.middleware.MessageMiddleware',
    'django.middleware.clickjacking.XFrameOptionsMiddleware',
    'DtTranslator.middleware.OAuthDt',
    'oauth2_provider.middleware.OAuth2TokenMiddleware',
]

有什么建议吗?

1 个答案:

答案 0 :(得分:0)

在检查了Oauth中间件之后,我只需要正确修改标头即可。

request.META['HTTP_AUTHORIZATION'] = "Bearer 123456"