Django drf使用Django自帶的用戶系統(tǒng)的注冊功能
在寫登錄功能的時候看著網(wǎng)上的視頻學著做,然后看了源碼的時候發(fā)現(xiàn)了一些有意思的功能,因此寫這一篇筆記分享給大家.
1.閱讀Django自帶用戶系統(tǒng)源碼
1.1 閱讀User類源碼
系統(tǒng)自帶的用戶系統(tǒng)的models文件的位置\site-packages\django\contrib\auth\models.py,打開這個文件發(fā)現(xiàn)User類繼承的是一個AbstractUser類,因此我們想要使用系統(tǒng)自帶的用戶系統(tǒng),只要在models中重新寫一個User類,也繼承AbstractUser就可以了.

1.2 閱讀AbstractUser類
閱讀AbstractUser類,發(fā)現(xiàn)了其中的對username字段做的幾個處理,第一個就是他添加了一個驗證器validators,第二個增加了error_messages,當在我們往數(shù)據(jù)庫中添加用戶信息的時候,系統(tǒng)就會自動驗證是否符合要求,如果不符合要求,就會返回一個字典,將對應字段的錯誤返回,這就是我想到的與其他博主所做的不同之處.

2.創(chuàng)建自己的User類
我想我的用戶類中有mobile,username,email,password四個字段,我的需求:
mobile,username,email都是不能重復
驗證這幾個字段的格式
返回的errormessage為中文
因此我就想到了模仿系統(tǒng)自帶的AbstractUser的寫法:
2.1 創(chuàng)建驗證器
這個驗證器是其中主要是驗證電話號碼和郵箱的格式正誤,因為其他的類也可能需要用到驗證器,因此我就在項目的utils目錄下創(chuàng)建了一個validator.py文件,用于專門存取驗證器.項目根目錄\utils\validator.py代碼:
# 驗證電話號碼是否有誤
import re
from django.core.exceptions import ValidationError
# 對手機格式進行驗證
class UnicodMobileValidator:
def __call__(self, value):
if not re.match(r"^1[3-9]\d{9}$", value):
raise ValidationError("對不起,手機格式有誤!")
# 對郵箱格式進行驗證
class UnicodEmailValidator:
def __call__(self, value):
if not re.match(r"^[a-zA-Z0-9_.-]+@[a-zA-Z0-9-]+(\.[a-zA-Z0-9-]+)*\.[a-zA-Z0-9]{2,6}$", value):
raise ValidationError("對不起,郵箱格式有誤!")2.2 創(chuàng)建User類
這里我繼承了AbstractUser類,并且重寫了其中的方法和屬性.user\models.py代碼:
from datetime import timezone
from django.contrib.auth.validators import UnicodeUsernameValidator
from django.db import models
from django.contrib.auth.models import AbstractBaseUser, PermissionsMixin, AbstractUser
from qianxingtong_main.utils.validator import UnicodMobileValidator, UnicodEmailValidator
class User(AbstractUser):
username_validator = UnicodeUsernameValidator()
username = models.CharField(
("username"),
max_length=150,
unique=True,
help_text=(
"Required. 150 characters or fewer. Letters, digits and @/./+/-/_ only."
),
validators=[username_validator],
error_messages={
"unique": ("該用戶名已經(jīng)存在"),
},
)
email = models.EmailField(("email address"), unique=True, validators=[UnicodEmailValidator()],error_messages={"unique": ("郵箱已經(jīng)存在"),})
mobile = models.CharField(max_length=15, unique=True, validators=[UnicodMobileValidator()],
error_messages={"unique": ("電話號碼已經(jīng)存在")}, verbose_name="手機號碼")
class Meta:
db_table = "drf_user"
verbose_name = "用戶信息"
verbose_name_plural = verbose_name
這里在遷移數(shù)據(jù)的時候可能會出現(xiàn)錯誤,其中錯誤的解決方法參考我寫的筆記:http://www.dbjr.com.cn/article/275133.htm 的第三步
3.創(chuàng)建序列化類
user\serializers代碼:
from django.contrib.auth.hashers import make_password
from rest_framework import serializers
from user.models import User
class UserSerializer(serializers.ModelSerializer):
rpassword = serializers.CharField(required=True, write_only=True, help_text="確認密碼")
token = serializers.CharField(max_length=1024, read_only=True, help_text="token認證字符串")
class Meta:
model = User
fields = ["id", "username", "email", "mobile", "password", "token", "rpassword"]
# write_only:只寫入數(shù)據(jù)庫,
extra_kwargs = {
"mobile": {
"write_only": True,
},
"email": {
"write_only": True,
},
"id": {
"read_only": True,
},
}
def validate(self, attrs):
"""校驗信息"""
password = attrs.get("password")
rpassword = attrs.get("rpassword")
if password != rpassword:
# 驗證手機號碼是否已經(jīng)被注冊
raise serializers.ValidationError("對不起,確認密碼與密碼不一致!")
return attrs
def create(self, validated_data):
"""保存用戶信息"""
mobile = validated_data.get("mobile")
username = validated_data.get("username")
email = validated_data.get("email")
validated_data.pop("rpassword") # 移除不需要的數(shù)據(jù)
# 對密碼進行加密
raw_password = validated_data.get("password")
hash_password = make_password(raw_password)
# 調(diào)用序列化器提供的create方法
user = User.objects.create(
mobile=mobile,
username=username,
password=hash_password,
email=email
)
return user這個代碼就是我與其他的博主不同的地方,我看網(wǎng)上的up主就是把驗證的代碼寫在validate中,但是這里存在的一個問題就是所有的錯誤都是統(tǒng)一一起打包返回,無法在前端中做對應字段的錯誤提示.
4.創(chuàng)建views類
user\views代碼:
from rest_framework.generics import CreateAPIView
from user.models import User
from user.serializers import UserSerializer
# Create your views here.
class UserViewSets(CreateAPIView):
queryset = User.objects.all()
serializer_class = UserSerializer5.創(chuàng)建路由

6.測試接口

從測試結(jié)果就可以看出,針對不同的字段,會返回對應的錯誤,而不是一起返回的.
到此這篇關于Django drf使用Django自帶的用戶系統(tǒng)的注冊功能 的文章就介紹到這了,更多相關Django drf用戶系統(tǒng)注冊內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Python實現(xiàn)用networkx繪制MultiDiGraph
這篇文章主要介紹了Python實現(xiàn)用networkx繪制MultiDiGraph方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-02-02
Python實現(xiàn)連接兩個無規(guī)則列表后刪除重復元素并升序排序的方法
這篇文章主要介紹了Python實現(xiàn)連接兩個無規(guī)則列表后刪除重復元素并升序排序的方法,涉及Python針對列表的合并、遍歷、判斷、追加、排序等操作技巧,需要的朋友可以參考下2018-02-02
python和shell實現(xiàn)的校驗IP地址合法性腳本分享
這篇文章主要介紹了python和shell實現(xiàn)的校驗IP地址合法性腳本分享,每個腳本配有執(zhí)行效果圖,需要的朋友可以參考下2014-10-10
Python 網(wǎng)絡編程之TCP客戶端/服務端功能示例【基于socket套接字】
這篇文章主要介紹了Python 網(wǎng)絡編程之TCP客戶端/服務端功能,結(jié)合實例形式分析了Python使用socket套接字實現(xiàn)TCP協(xié)議下的客戶端與服務器端數(shù)據(jù)傳輸操作技巧,需要的朋友可以參考下2019-10-10

