我正在使用带有Django Rest Framework的Django和带有CoffeScript的AngularJS构建应用程序。我基于教程https://thinkster.io/brewer/angular-django-tutorial/。我从客户端传递json有问题,但我认为问题显然在我看来,因为即使通过DRF api发布json也会产生同样的错误 - "没有JSON对象可以被解码"由行data = json.loads(request.body)
引起。
我的APIView正在关注(与教程中的内容完全相同):
class LoginView(views.APIView):
def post(self, request, format=None):
data = json.loads(request.body)
email = data.get('email', None)
password = data.get('password', None)
account = authenticate(email=email, password=password)
if account is not None:
if account.is_active:
login(request, account)
serialized = AccountSerializer(account)
return Response(serialized.data)
else:
return Response({
'status': 'Unathorized',
'message': 'This account has been disabled.'
}, status=status.HTTP_401_UNATHORIZED)
else:
return Response({
'status': 'Unathorized',
'message': 'Username/password combination invalid.'
}, status=status.HTTP_401_UNATHORIZED)
当我尝试从api传递JSON并尝试在控制台中打印request.body时,我得到了这样的结果:
csrfmiddlewaretoken=s2dIiOy7eNUJJfGBRaDAFmJ632kjbokz&_content_type=application%2Fjson&_content=%7B%0D%0A%22email%22%3A+%22example@ex.com%22%2C%0D%0A%22password%22%3A+%22example%22%0D%0A%7
它似乎不是一个正确的JSON。我认为这种观点有问题吗?或者我应该在其他地方看看?
答案 0 :(得分:3)
我遇到了同样的问题。
email = request.data.get('email', None)
password = request.data.get('password', None)
这解决了我的问题。
答案 1 :(得分:-1)
您没有将响应转换为实际的JSON。
示例:
else:
return Response(json.dumps({
'status': 'Unathorized',
'message': 'Username/password combination invalid.'
}), status=status.HTTP_401_UNATHORIZED)
答案 2 :(得分:-1)
您尚未展示您的JS代码,但似乎您是以表单编码格式发布数据,而JSON本身位于content
字段中。所以你会这样得到:
data = json.loads(request.POST['content'])