【发布时间】:2015-01-11 13:36:15
【问题描述】:
我正在使用带有 Django Rest Framework 的 Django 和带有 CoffeScript 的 AngularJS 构建一个应用程序。我基于教程https://thinkster.io/brewer/angular-django-tutorial/。我在从客户端传递 json 时遇到问题,但我认为这个问题在我看来很明显,因为即使通过 DRF api 发布 json 也会出现相同的错误 - “无法解码 JSON 对象”是由 @987654322 行引起的@。
我的 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。我认为这种观点有问题是对的吗?还是应该去别的地方看看?
【问题讨论】: