实现一个django auth的注册模块 包括 用户名的唯一性验证和密码与确认密码的一致性验证以及注册后成功的提示信息
时间: 2024-03-13 18:45:35 浏览: 13
好的,下面是一个简单的 Django auth 注册模块实现:
1. 首先在 `settings.py` 中配置 `AUTH_USER_MODEL`,指定用户模型为自定义模型,例如:
```python
AUTH_USER_MODEL = 'myapp.MyUser'
```
2. 然后在 `forms.py` 中定义注册表单,包括用户名、邮箱、密码和确认密码:
```python
from django import forms
from django.contrib.auth.forms import UserCreationForm
from .models import MyUser
class SignUpForm(UserCreationForm):
email = forms.EmailField(max_length=254, required=True)
class Meta:
model = MyUser
fields = ('username', 'email', 'password1', 'password2',)
```
3. 在 `views.py` 中定义注册视图函数,实现用户名唯一性验证和密码一致性验证:
```python
from django.shortcuts import render, redirect
from django.contrib.auth import login
from .forms import SignUpForm
def signup(request):
if request.method == 'POST':
form = SignUpForm(request.POST)
if form.is_valid():
user = form.save(commit=False)
user.save()
login(request, user)
messages.success(request, '注册成功!')
return redirect('home')
else:
form = SignUpForm()
return render(request, 'signup.html', {'form': form})
```
4. 最后在 `signup.html` 模板中渲染注册表单,并显示错误信息和成功提示信息:
```html
{% extends 'base.html' %}
{% block content %}
<h2>注册</h2>
<form method="post">
{% csrf_token %}
{{ form.as_p }}
<button type="submit">注册</button>
</form>
{% if form.errors %}
<div class="alert alert-danger">
{% for field in form %}
{% for error in field.errors %}
<p>{{ error }}</p>
{% endfor %}
{% endfor %}
</div>
{% endif %}
{% if messages %}
<div class="alert alert-success">
<p>{{ messages }}</p>
</div>
{% endif %}
{% endblock %}
```
这样,一个包括用户名唯一性验证和密码一致性验证的 Django auth 注册模块就完成了。