所以我试图在使用django rest框架的应用程序中提供用户注册。我面临的问题是DRF基本上要求对请求进行身份验证
这是设置:
DEFAULT_AUTHENTICATION = {
'DEFAULT_AUTHENTICATION_CLASSES': (
'rest_framework.authentication.OAuth2Authentication',
),
}
这是观点:
@permission_classes((AllowAny,))
@csrf_exempt
@api_view(['POST'])
def create_auth(request, format=None):
data = JSONParser().parse(request)
serialized = UserSerializer(data=data)
if serialized.is_valid():
user = User.objects.create_user(
serialized.init_data['email'],
serialized.init_data['username'],
serialized.init_data['password'],
)
user.groups = serialized.init_data['groups']
user.save()
serialized_user = UserSerializer(user)
return Response(serialized_user.data, status=status.HTTP_201_CREATED, headers={"Access-Control-Allow-Origin": "http://127.0.0.1:8000/"})
else:
return Response(serialized._errors, status=status.HTTP_400_BAD_REQUEST, headers={"Access-Control-Allow-Origin": "http://127.0.0.1:8000/"})
这是测试:
def test_user_register(self):
user_data = {'username': 'testusername',
'email': "test@test.com",
'groups': [1],
'password': 'testpassword',
}
resp = self.client.post("/auth/register", json.dumps(user_data), content_type="application/json")
print resp.content
self.assertEquals(resp.status_code, 200)
self.assertContains(resp, user_data["username"], 1, 201)
这是错误:
{"detail": "Authentication credentials were not provided."}
我做错了什么?是不是装饰者应该允许未经过身份验证的请求? 更好的是:哪种是通过REST API注册用户的正确方法?
谢谢, 阿迪