我正在使用DRF ( djangorestframework_simplejwt ) 建议的库,使用安装
pip install djangorestframework_simplejwt
将其添加到 settings.py
REST_FRAMEWORK = {
'DEFAULT_AUTHENTICATION_CLASSES': [
'rest_framework_simplejwt.authentication.JWTAuthentication',
]
}
从导入的视图创建两个端点
from rest_framework_simplejwt.views import TokenObtainPairView, TokenRefreshView
urlpatterns = [
# JWT Token
path('api/token/', TokenObtainPairView.as_view(), name='token_obtain'),
# get a new token before the old expires.
path('api/token/refresh/', TokenRefreshView.as_view, name='token_refresh'),
]
在数据库中创建用户没有任何问题,并且正在对密码进行哈希处理。
如果我去http://localhost:8000/api/token/,然后得到以下视图
使用密码发布正确的用户,然后我收到以下错误
[2020 年 4 月 17 日 12:06:51]“POST /api/token/HTTP/1.1”500 122221 内部服务器错误:/api/token/ Traceback(最后一次调用):文件“C:\Users\tiago \Desktop\letsgo\authenticationJwt\lib\site-packages\django\core\handlers\exception.py”,第 34 行,内部响应 = get_response(request) 文件“C:\Users\tiago\Desktop\letsgo\authenticationJwt\ lib\site-packages\django\core\handlers\base.py”,第 115 行,在 _get_response 响应 = self.process_exception_by_middleware(e, request) 文件“C:\Users\tiago\Desktop\letsgo\authenticationJwt\lib\site -packages\django\core\handlers\base.py”,第 113 行,在 _get_response 响应 = Wrapped_callback(request, *callback_args, **callback_kwargs) 文件“C:\Users\tiago\Desktop\letsgo\authenticationJwt\lib\site-packages\django\views\decorators\csrf.py”,第 54 行,在 Wrapped_view 返回 view_func(*args, **kwargs) 文件“C:\Users\ tiago\Desktop\letsgo\authenticationJwt\lib\site-packages\django\views\generic\base.py”,第 71 行,在视图中返回 self.dispatch(request, *args, **kwargs) 文件“C:\Users \tiago\Desktop\letsgo\authenticationJwt\lib\site-packages\rest_framework\views.py”,第 505 行,在调度响应 = self.handle_exception(exc) 文件“C:\Users\tiago\Desktop\letsgo\authenticationJwt\ lib\site-packages\rest_framework\views.py”,第 465 行,在 handle_exception self.raise_uncaught_exception(exc) 文件“C:\Users\tiago\Desktop\letsgo\authenticationJwt\lib\site-packages\rest_framework\views.py ",第 476 行,在 raise_uncaught_exception raise exc 文件“C:\Users\tiago\Desktop\letsgo\authenticationJwt\lib\site-packages\rest_framework\views.py”,第 502 行,在调度响应 = handler(request, *args, **kwargs)文件“C:\Users\tiago\Desktop\letsgo\authenticationJwt\lib\site-packages\rest_framework_simplejwt\views.py”,第 27 行,在 post serializer.is_valid(raise_exception=True) 文件“C:\Users\tiago\ Desktop\letsgo\authenticationJwt\lib\site-packages\rest_framework\serializers.py”,第 234 行,在 is_valid self._validated_data = self.run_validation(self.initial_data) 文件“C:\Users\tiago\Desktop\letsgo\authenticationJwt \lib\site-packages\rest_framework\serializers.py",第 436 行,在 run_validation value = self.validate(value) File "C:\Users\tiago\Desktop\letsgo\authenticationJwt\lib\site-packages\rest_framework_simplejwt\serializers.py",第 73 行,在验证刷新 = self.get_token(self.user) 文件“C:\Users\tiago\Desktop\ letsgo\authenticationJwt\lib\site-packages\rest_framework_simplejwt\serializers.py”,第 68 行,在 get_token 中返回 RefreshToken.for_user(user) 文件“C:\Users\tiago\Desktop\letsgo\authenticationJwt\lib\site-packages\ rest_framework_simplejwt\tokens.py",第 161 行,在 for_user user_id = getattr(user, api_settings.USER_ID_FIELD) AttributeError: 'MyUser' object has no attribute 'id'\Users\tiago\Desktop\letsgo\authenticationJwt\lib\site-packages\rest_framework_simplejwt\serializers.py”,第 68 行,在 get_token 中返回 RefreshToken.for_user(user) 文件“C:\Users\tiago\Desktop\letsgo\authenticationJwt \lib\site-packages\rest_framework_simplejwt\tokens.py",第 161 行,在 for_user user_id = getattr(user, api_settings.USER_ID_FIELD) AttributeError: 'MyUser' object has no attribute 'id'\Users\tiago\Desktop\letsgo\authenticationJwt\lib\site-packages\rest_framework_simplejwt\serializers.py”,第 68 行,在 get_token 中返回 RefreshToken.for_user(user) 文件“C:\Users\tiago\Desktop\letsgo\authenticationJwt \lib\site-packages\rest_framework_simplejwt\tokens.py",第 161 行,在 for_user user_id = getattr(user, api_settings.USER_ID_FIELD) AttributeError: 'MyUser' object has no attribute 'id'
错误很明显,MyUser 对象没有属性 id。相反,它有user_id
一个primary_key,如下所示
class MyUser(AbstractBaseUser):
user_id = models.AutoField(primary_key=True, db_column='userId')
password = models.CharField(db_column='userPassword', max_length=256)
email = models.EmailField(verbose_name='email', max_length=100, unique=True)
问题是,我不想更改当前的 MyUser 字段。
编辑
转到djangorestframework_simplejwt的设置,可以阅读
DEFAULTS = {
...
'USER_ID_FIELD': 'id',
...
}
因此,考虑到我不想将 MyUser primary_key 更改为 id,我去了安装 djangorestframework_simplejwt 的地方并搜索了声明 USER_ID_FIELD 的地方。
仅在 SIMPLE_JWT 的 venv\Jwt\Lib\site-packages\djangorestframework_simplejwt-4.4.0.dist-info\METADATA 中找到它。在那里,改为
SIMPLE_JWT = {
...
'USER_ID_FIELD': 'user_id',
...
}
然后,重新启动 venv 和 runserver。问题仍然存在。