6

这是我的 serializers.py(我想为内置的 User 模型创建一个序列化程序):

from rest_framework import serializers

from django.contrib.auth.models import User

class UserSerializer(serializers.ModelSerializer):

    class Meta:
        model = User
        fields = ('username', 'password', 'email', )

    def validate_username(self, username):
        if not re.search(r'^\w+$', username): #checks if all the characters in username are in the regex. If they aren't, it returns None
            raise serializers.ValidationError('Username can only contain alphanumeric characters and the underscore.')
        try:
            User.objects.get(username=username)
        except ObjectDoesNotExist:
            return username
        raise serializers.ValidationError('Username is already taken.')

问题是,当我尝试使用已经存在的用户名创建用户时,它返回以下字典:

{'username': [u'This field must be unique.']}

而不是说

{'username': [u'Username is already taken']}

我为此重新创建了 validate_username 函数(用于测试目的):

    def validate_username(self, username):
        raise serializers.ValidationError('Testing to see if an error is raised.')

它不会引发错误。知道为什么 DjangoRestFramework 会忽略 validate_username 函数吗?

编辑:请注意,我使用的是 ModelSerializer(在此处的教程中:http: //www.django-rest-framework.org/api-guide/serializers/#validation它仅讨论了序列化器的字段级验证,而不是一个模型序列化器)。注意确定它是否有所作为。

4

2 回答 2

6

在序列化程序级别验证之前调用字段级别验证。

因此User,具有 username asunique=True的模型,字段级验证将引发异常,因为 username 已经存在。UniqueValidator当字段不唯一时,DRF 会执行引发异常的工作。

根据 DRF 源代码,

class UniqueValidator:
    """
    Validator that corresponds to `unique=True` on a model field.

    Should be applied to an individual field on the serializer.
    """
    message = _('This field must be unique.')

由于这些验证器在序列化程序级别验证之前运行,因此您validate_username永远不会被调用。

于 2015-06-04T09:34:28.873 回答
1

尝试在您的序列化程序中添加以下行以使此验证器正常工作。

class UserSerializer(serializers.ModelSerializer):
    username = serializers.CharField(max_length=32)

class Meta:
    model = User
    fields = ('username', 'password', 'email', )
于 2020-02-25T08:14:46.323 回答