令牌认证在django rest框架中的生产中不起作用

jab*_*bez 10 python authentication django django-rest-framework django-rest-auth

我有这个奇怪的问题,我找不到原因.我使用django 1.7和django rest框架和用于api身份验证的令牌身份验证来构建API.所有在本地主机上工作正常,但是当我尝试调用需要在生产计算机上进行身份验证的API端点时,我将获得403状态代码以及以下消息:{"detail":"未提供身份验证凭据". }.我做错了什么?

我按照文档在标题中发送令牌.以下是我的设置文件的外观:

INSTALLED APPLICATIONS = (
    '......',
    'rest_framework',
    'rest_framework.authtoken',
    'rest_framework_swagger',
    'corsheaders',
    '......')

MIDDLEWARE_CLASSES = (
    'corsheaders.middleware.CorsMiddleware',
    'django.contrib.sessions.middleware.SessionMiddleware',
    'django.middleware.csrf.CsrfViewMiddleware',
    'django.contrib.auth.middleware.AuthenticationMiddleware',
    'django.contrib.messages.middleware.MessageMiddleware',
    'django.middleware.locale.LocaleMiddleware',
    'django.contrib.admindocs.middleware.XViewMiddleware',
    'django.middleware.common.CommonMiddleware',
    'admin_reorder.middleware.ModelAdminReorder',
)

REST_FRAMEWORK = {
    'DEFAULT_PERMISSION_CLASSES': [
        'rest_framework.permissions.AllowAny'
    ],
    'DEFAULT_AUTHENTICATION_CLASSES': (
        'rest_framework.authentication.SessionAuthentication',
        'rest_framework.authentication.TokenAuthentication',
    ),
    'PAGINATE_BY_PARAM': 'page_size',
    'DEFAULT_PAGINATION_CLASS': 'rest_framework.pagination.PageNumberPagination',
    'DEFAULT_FILTER_BACKENDS': ('rest_framework.filters.DjangoFilterBackend',),
    'VIEW_DESCRIPTION_FUNCTION': 'rest_framework_swagger.views.get_restructuredtext'
}

REST_SESSION_LOGIN = False
CORS_ORIGIN_ALLOW_ALL = True
Run Code Online (Sandbox Code Playgroud)

Tro*_*nic 12

对我来说,问题是Apache没有将Authorization-Header转发给WSGI-Process.这是修复:

只需添加

WSGIPassAuthorization on
Run Code Online (Sandbox Code Playgroud)

到你的Apache(vhost)配置.

  • 救星!要在AWS ElasticBeanstalk上实现此功能,请添加一个容器命令,例如:`03wsgipass:command:'echo“ WSGIPassAuthorization On” >> ../ wsgi.conf'` https://docs.aws.amazon.com/elasticbeanstalk/latest /dg/create-deploy-python-container.html#create-deploy-python-custom-container (4认同)