Сериализатор Django
этот сериализатор
class RegisterSerializer(serializers.ModelSerializer):
class Meta:
model = User
fields = ['id', 'username', 'email', 'password']
extra_kwargs = {'password': {'write_only': True}}
def create(self, validated_data):
#user = super(RegisterSerializer, self).create(validated_data)
user = User.objects.create_user(**validated_data)
return user
и Loginserializer :
class LoginSerializer(serializers.Serializer):
username = serializers.CharField()
password = serializers.CharField()
def validate(self, data):
username = data.get('username')
password = data.get('password')
if username and password:
user = authenticate(username=username, password=password)
if user and user.is_active:
return user
raise serializers.ValidationError("Invalid credentials!")
Я использовал этот код и он работал хорошо, но когда я изменил мой Register serialzer
class RegisterSerializer(serializers.ModelSerializer):
class Meta:
model = User
fields = ['id', 'username', 'email', 'password']
extra_kwargs = {'password': {'write_only': True}}
def create(self, validated_data):
user = super(RegisterSerializer, self).create(validated_data)
return user
код работает не очень хорошо. Когда я хочу протестировать свою конечную точку в Postman, код создает пользователя очень хорошо, но для входа в конечную точку я всегда получаю этот ответ Invalid credentials
Я не знаю, что произошло, когда я изменил свой код, сначала он работал хорошо, но когда я добавил эту строку, он не работал "user = super(RegisterSerializer, self).create(validated_data)"
Ваша проблема заключается в том, что user = super(RegisterSerializer, self).create(validated_data)
хранит пароль в базе данных в виде обычного текста, в то время как django ожидает, что он будет хэширован. Вы можете проверить это, запустив python manage.py shell
и выполнив:
from django.contrib.auth import get_user_model
UserModel = get_user_model()
UserModel.objects.first().password
Это должно вернуть что-то вроде pbkdf2_sha256$...
. Если он возвращает plaintextpassword
, у вас две проблемы:
- хранение паролей в открытом виде - кошмар безопасности
- вход в систему через джанго не работает так, как ожидалось
Чтобы решить эту проблему, просто хэшируйте пароль вручную в сериализаторе:
class RegisterSerializer(serializers.ModelSerializer):
class Meta:
model = User
fields = ['id', 'username', 'email', 'password']
extra_kwargs = {'password': {'write_only': True}}
def create(self, validated_data):
user = super(RegisterSerializer, self).create(validated_data)
user.set_password(user.password) # set_password hashes input.
user.save()
return user