【发布时间】:2015-02-05 06:04:38
【问题描述】:
我尝试使用 OAuth Toolkit 向我的 Rest API 添加身份验证。我进入登录页面并输入我的用户名和密码,然后重定向到我的 api。然后我收到一条消息 {"detail":"Authentication credentials were not provided."} 我已经尝试对此进行调查,大多数有问题的人似乎都错过了 Rest_Framework 设置中的某些内容。不过我想我没有。
这是我的代码:
设置.py
LOGIN_REDIRECT_URL = '/api/users/'
REST_FRAMEWORK = {
'DEFAULT_AUTHENTICATION_CLASSES': (
'rest_framework.authentication.TokenAuthentication',
'oauth2_provider.ext.rest_framework.OAuth2Authentication',
),
'DEFAULT_PERMISSION_CLASSES': (
'rest_framework.permissions.IsAdminUser',
),
'DEFAULT_RENDERER_CLASSES': (
'rest_framework.renderers.JSONRenderer',
),
'DEFAULT_PARSER_CLASSES': (
'rest_framework.parsers.JSONParser',
),
}
url.py
urlpatterns = patterns('', url(r'^admin/', include(admin.site.urls)),
url(r'^accounts/login/$', auth_views.login, {'template_name': 'login.html'}),
url(r'^api-auth/', include('rest_framework.urls', namespace='rest_framework')),
url(r'^api-token-auth/', 'rest_framework.authtoken.views.obtain_auth_token'),
url(r'^o/', include('oauth2_provider.urls', namespace='oauth2_provider')),
url(r'^api/users/$', api.UserList.as_view()),
url(r'^api/users/(?P<pk>[0-9+]+)/$', api.UserDetail.as_view()),
)
api.py
@receiver(post_save, sender=User)
def init_new_user(sender, instance, signal, created, **kwargs):
if created:
Token.objects.create(user=instance)
class APIEndpoint(ProtectedResourceView):
def get(self, request, *args, **kwargs):
return HttpResponse('Protected with OAuth2!')
class UserViewSet(viewsets.ModelViewSet):
model = User
serializer_class = UserSerializer
def retrieve(self, request, pk=None):
if pk == 'me':
return Response(UserSerializer(request.user).data)
return super(UserViewSet, self).retrieve(request, pk)
class UserList(generics.ListCreateAPIView):
queryset = User.objects.all()
serializer_class = UserSerializer
class UserDetail(generics.RetrieveUpdateDestroyAPIView):
queryset = User.objects.all()
serializer_class = UserSerializer
【问题讨论】:
-
对这些解决方案有帮助:stackoverflow.com/questions/14877249
-
我看了这些,但仍然没有运气。从那里我唯一没有尝试的是
WSGIPassAuthorization On,据我所知,如果你在Apache服务器上运行,而我只是运行virtualenv。如果我错了,我不知道在哪里放WSGIPassAuthorization On -
你是对的,这是一个 Apache 特定的配置选项。您的设置文件中的
INSTALLED_APPS中有oauth2_provider列表吗? -
嗯,我唯一能想到的另一件事就是尝试切换
DEFAULT_AUTHENTICATION_CLASSES的顺序,让OAuth2在前。 -
你得到的响应码是什么?
标签: python django rest django-rest-framework