0

最近 Python 2.7 から 3.4 に更新した Django REST サーバーがあります。サーバーは、Django の上で Django REST フレームワークを使用し、Facebook ログインをサポートするために django-allauth および django-rest-auth を使用します。

更新後、Facebookでサーバーにログインできなくなりました。サーバーに POST を送信すると、次のエラーが表示されます。

Internal Server Error: /rest-auth/facebook/
Traceback (most recent call last):
  File "C:\Python34\lib\site-packages\django\core\handlers\base.py", line 132, in get_response response = wrapped_callback(request, *callback_args, **callback_kwargs)
  File "C:\Python34\lib\site-packages\django\views\decorators\csrf.py", line 58, in wrapped_view return view_func(*args, **kwargs)
  File "C:\Python34\lib\site-packages\django\views\generic\base.py", line 71, in view return self.dispatch(request, *args, **kwargs)
  File "C:\Python34\lib\site-packages\rest_framework\views.py", line 452, in dispatch response = self.handle_exception(exc)
  File "C:\Python34\lib\site-packages\rest_framework\views.py", line 449, in dispatch response = handler(request, *args, **kwargs)
  File "C:\Python34\lib\site-packages\rest_auth\views.py", line 51, in post if not self.serializer.is_valid():
  File "C:\Python34\lib\site-packages\rest_framework\serializers.py", line 187, in is_valid self._validated_data = self.run_validation(self.initial_data)
  File "C:\Python34\lib\site-packages\rest_framework\serializers.py", line 370, in run_validation value = self.validate(value)
  File "C:\Python34\lib\site-packages\rest_auth\registration\serializers.py", line 31, in validate token.account = login.account
  File "C:\Python34\lib\site-packages\django\db\models\fields\related.py", line 668, in __set__ (value, self.field.rel.to._meta.object_name)
  File "C:\Python34\lib\site-packages\django\db\models\base.py", line 496, in __repr__ u = six.text_type(self)
  File "C:\Python34\lib\site-packages\allauth\socialaccount\models.py", line 104, in __str__ return force_text(self.user)
  File "C:\Python34\lib\site-packages\django\db\models\fields\related.py", line 608, in __get__ "%s has no %s." % (self.field.model.__name__, self.field.name)
django.db.models.fields.related.RelatedObjectDoesNotExist: SocialAccount has no user.
[13/Apr/2015 08:53:30]"POST /rest-auth/facebook/ HTTP/1.1" 500 115908

何が原因でしょうか? Python とライブラリを更新した後、コードに変更を加えていません。更新前は機能していました。古いデータベースを削除し、syncdb を介して新しいデータベースを作成しましたが、役に立ちませんでした。

前もって感謝します。

4

1 に答える 1

0

RelatedObjectは Django 1.8 で削除され、 が採用されましたForeignObjectRelソース

使用している allauth バージョンは Django 1.8 をサポートしていません。

于 2015-04-13T06:35:35.460 に答える