Django drf simple-jwt身份验证“详细信息”:“未找到具有给定凭据的活动帐户”

时间:2019-04-29 15:55:13

标签: django django-rest-framework django-rest-framework-simplejwt

我正在使用django-rest_framework_simple-jwt和自定义用户来实现用户身份验证, 我的models.py:

class UserManager(BaseUserManager):
    def create_user(self, email, username, password, alias=None):
        user = self.model(
        email = self.normalize_email(email),
                username = username,)
        user.set_password(password)
        user.save()
        return user
   def create_superuser(self, email, username, password):
       self.create_user(email, username, password)
       user.is_staff()
       user.is_superuser = True
       user.save()
       return user

class User(AbstractBaseUser, PermissionsMixin):
    email = models.EmailField(null=False, unique=True)
    username = models.CharField(max_length=25, unique=True)
    is_active = models.BooleanField(default=True)
    is_staff = models.BooleanField(default=False)

    objects = UserManager()
    USERNAME_FIELD = "email"
    REQUIRED_FIELDS = ["username",]

所以我正在实现restframework simple-jwt身份验证,我的设置.py如下:

REST_FRAMEWORK={
  'DEFAULT_AUTHENTICATION_CLASSES': [
      'rest_framework_simplejwt.authentication.JWTAuthentication',
   ]}

我的urls.py:

urlpatterns = [
       url(r'^api/token/$', TokenObtainPairView.as_view(),  name='token_obtain_pair'),
       url(r'^api/token/refresh/$', TokenRefreshView.as_view(), name='token_refresh'),]

在登录过程中,它返回错误提示"detail": "No active account found with the given credentials"我所有的用户都处于活动状态。我不知道如何解决这个问题,需要帮助。谢谢。

7 个答案:

答案 0 :(得分:0)

您记得设置过吗:

"""C:\Java\jre8\bin\java"" -Djava.library.path=""C:\some\path\lib"" -classpath ""some;long;classpath"" com.foo.app.Main"

答案 1 :(得分:0)

在将密码存储在数据库中之前,请确保对密码进行哈希处理。我遇到了同样的问题,发现我的密码以纯文本格式存储。将以下内容添加到我的UserSerializer中可以解决此问题

from django.contrib.auth.hashers import make_password

def validate_password(self, value: str) -> str:
    """
    Hash value passed by user.

    :param value: password of a user
    :return: a hashed version of the password
    """
    return make_password(value)

答案 2 :(得分:0)

设置create new superuser account后,您应该JWT authentication

然后使用accountget the token

python manage.py createsuperuser

答案 3 :(得分:0)

我的错误似乎是由密码字段上的write_only参数引起的

class RegisterSerializer(serializers.ModelSerializer):
    password = serializers.CharField(
        max_length=68, min_length=6, write_only=True)


    class Meta:
        model = User
        fields = ['email', 'username', 'password']

已将其删除:

class RegisterSerializer(serializers.ModelSerializer):
    password = serializers.CharField(
        max_length=68, min_length=6)


    class Meta:
        model = User
        fields = ['email', 'username', 'password']

然后是所有的阳光和彩虹:-)

答案 4 :(得分:0)

您没有为Django应用程序创建超级用户,或者为您提供了错误的身份验证凭据

答案 5 :(得分:0)

试试这个

from django.contrib.auth.hashers import make_password

class UserManager(BaseUserManager):
def create_user(self, email, username, password, alias=None):
    user = self.model(
    email = self.normalize_email(email),
            username = username,)
    user.set_password(make_password(password))
    user.save()
    return user
def create_superuser(self, email, username, password):
   self.create_user(email, username, password)
   user.is_staff()
   user.is_superuser = True
   user.save()
   return user

答案 6 :(得分:0)

手动从 PyJWT==2.0.0 降级到 PyJWT==1.7.1 解决了我们的问题

pip install PyJWT==1.7.1

我们在 requirements.txt 上使用 djangorestframework==3.12.1 和 djangorestframework-simplejwt==4.4.0,这自动给了我们 2.0.0 版本依赖。