如何编辑或自定义用户名字段所需的字符?



我正在做一个博客类型的网站,它几乎已经完成了,但是今天早些时候我意识到它的一个主要缺陷。当创建一个用户名时(当注册或编辑一个人的个人资料时),它要求某些字符,但它不允许我在我的名字中有空格。

例如如果我想让我的用户名是"Winston pichardo",这是不可能的,因为这会触发错误,说"只有字母和数字为@/"。/+/-/_ "

那么我如何编辑这些"要求"以允许用户名中的空格?

我使用默认的django表单,并将其与Crispy forms相结合,使其全部工作。

这些是我代码的一些例子:

forms.py

class UserRegisterForm(UserCreationForm):
email = forms.EmailField(
label= 'Correo Electrónico',
required=True,
)
username = forms.CharField(
label = 'Nombre de Usuario',
required=True,
)
password1 = forms.CharField(
label = "Contraseña",
required=True
)
password2 = forms.CharField(
label = "Confirmar Contraseña",
required=True
)
class Meta:
model = User
fields = ['username', 'email', 'password1', 'password2']
class UserUpdateForm(forms.ModelForm):
email = forms.EmailField(
label='Correo Electrónico',
required=True
)
username = forms.CharField(
required=True,
label='Nombre de Usuario'
)

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

class ProfileUpdateForm(forms.ModelForm):
image = forms.ImageField(
label = 'Foto de perfil'
)
class Meta:
model = Profile
fields = ['image']

register.html

{% extends "blog/base.html" %}
{% load crispy_forms_tags %}
{% block content %}
<div class="content-section">
<form method="POST">
{% csrf_token %}
<fieldset class="form-group">
<legend class="border-bottom mb-4">Cree su cuenta</legend>
{{ form|crispy }}
</fieldset>
<div>
<div class="form-group">
<button class="btn btn-outline-info" type="submit">Registrarse</button>
</div>
</form>
<div class="border-top pt-3">
<small class="text-muted">
¿Ya tiene una cuenta? <a class="ml-2" href='{% url 'login' %}'>Inicie sesión</a>
</small>
</div>
</div>             
{% endblock content %}

apps.py

class UsersConfig(AppConfig):
default_auto_field = 'django.db.models.BigAutoField'
name = 'users'
def ready(self):
import users.signals

如果你们需要我的代码中的其他内容,请随时告诉我。

方法之一是你可以更新你的模型的用户名字段,并可以添加验证器,如:

username = models.CharField(max_length=30, unique=True, 
validators=[
validators.RegexValidator(r'^[w. @+-]+$', _('Enter a valid username.'), 'invalid')
])

相关内容

  • 没有找到相关文章

最新更新