Django drf使用Django自帶的用戶系統(tǒng)的注冊(cè)功能
在寫登錄功能的時(shí)候看著網(wǎng)上的視頻學(xué)著做,然后看了源碼的時(shí)候發(fā)現(xiàn)了一些有意思的功能,因此寫這一篇筆記分享給大家.
1.閱讀Django自帶用戶系統(tǒng)源碼
1.1 閱讀User類源碼
系統(tǒng)自帶的用戶系統(tǒng)的models
文件的位置\site-packages\django\contrib\auth\models.py
,打開這個(gè)文件發(fā)現(xiàn)User類
繼承的是一個(gè)AbstractUser
類,因此我們想要使用系統(tǒng)自帶的用戶系統(tǒng),只要在models
中重新寫一個(gè)User
類,也繼承AbstractUser
就可以了.
1.2 閱讀AbstractUser類
閱讀AbstractUser
類,發(fā)現(xiàn)了其中的對(duì)username
字段做的幾個(gè)處理,第一個(gè)就是他添加了一個(gè)驗(yàn)證器validators
,第二個(gè)增加了error_messages
,當(dāng)在我們往數(shù)據(jù)庫(kù)中添加用戶信息的時(shí)候,系統(tǒng)就會(huì)自動(dòng)驗(yàn)證是否符合要求,如果不符合要求,就會(huì)返回一個(gè)字典,將對(duì)應(yīng)字段的錯(cuò)誤返回,這就是我想到的與其他博主所做的不同之處.
2.創(chuàng)建自己的User類
我想我的用戶類中有mobile,username,email,password四個(gè)字段,我的需求:
mobile,username,email都是不能重復(fù)
驗(yàn)證這幾個(gè)字段的格式
返回的errormessage為中文
因此我就想到了模仿系統(tǒng)自帶的AbstractUser
的寫法:
2.1 創(chuàng)建驗(yàn)證器
這個(gè)驗(yàn)證器是其中主要是驗(yàn)證電話號(hào)碼和郵箱的格式正誤,因?yàn)槠渌念愐部赡苄枰玫津?yàn)證器,因此我就在項(xiàng)目的utils
目錄下創(chuàng)建了一個(gè)validator.py
文件,用于專門存取驗(yàn)證器.項(xiàng)目根目錄\utils\validator.py
代碼:
# 驗(yàn)證電話號(hào)碼是否有誤 import re from django.core.exceptions import ValidationError # 對(duì)手機(jī)格式進(jìn)行驗(yàn)證 class UnicodMobileValidator: def __call__(self, value): if not re.match(r"^1[3-9]\d{9}$", value): raise ValidationError("對(duì)不起,手機(jī)格式有誤!") # 對(duì)郵箱格式進(jìn)行驗(yàn)證 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("對(duì)不起,郵箱格式有誤!")
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": ("電話號(hào)碼已經(jīng)存在")}, verbose_name="手機(jī)號(hào)碼") class Meta: db_table = "drf_user" verbose_name = "用戶信息" verbose_name_plural = verbose_name
這里在遷移數(shù)據(jù)的時(shí)候可能會(huì)出現(xiàn)錯(cuò)誤,其中錯(cuò)誤的解決方法參考我寫的筆記: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="確認(rèn)密碼") token = serializers.CharField(max_length=1024, read_only=True, help_text="token認(rèn)證字符串") class Meta: model = User fields = ["id", "username", "email", "mobile", "password", "token", "rpassword"] # write_only:只寫入數(shù)據(jù)庫(kù), extra_kwargs = { "mobile": { "write_only": True, }, "email": { "write_only": True, }, "id": { "read_only": True, }, } def validate(self, attrs): """校驗(yàn)信息""" password = attrs.get("password") rpassword = attrs.get("rpassword") if password != rpassword: # 驗(yàn)證手機(jī)號(hào)碼是否已經(jīng)被注冊(cè) raise serializers.ValidationError("對(duì)不起,確認(rèn)密碼與密碼不一致!") 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ù) # 對(duì)密碼進(jìn)行加密 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
這個(gè)代碼就是我與其他的博主不同的地方,我看網(wǎng)上的up主就是把驗(yàn)證的代碼寫在validate
中,但是這里存在的一個(gè)問題就是所有的錯(cuò)誤都是統(tǒng)一一起打包返回,無(wú)法在前端中做對(duì)應(yīng)字段的錯(cuò)誤提示.
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 = UserSerializer
5.創(chuàng)建路由
6.測(cè)試接口
從測(cè)試結(jié)果就可以看出,針對(duì)不同的字段,會(huì)返回對(duì)應(yīng)的錯(cuò)誤,而不是一起返回的.
到此這篇關(guān)于Django drf使用Django自帶的用戶系統(tǒng)的注冊(cè)功能 的文章就介紹到這了,更多相關(guān)Django drf用戶系統(tǒng)注冊(cè)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python元類編程實(shí)現(xiàn)一個(gè)簡(jiǎn)單的ORM
本文主要介紹了Python元類編程實(shí)現(xiàn)一個(gè)簡(jiǎn)單的ORM,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-03-03Python實(shí)現(xiàn)用networkx繪制MultiDiGraph
這篇文章主要介紹了Python實(shí)現(xiàn)用networkx繪制MultiDiGraph方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-02-02Python實(shí)現(xiàn)連接兩個(gè)無(wú)規(guī)則列表后刪除重復(fù)元素并升序排序的方法
這篇文章主要介紹了Python實(shí)現(xiàn)連接兩個(gè)無(wú)規(guī)則列表后刪除重復(fù)元素并升序排序的方法,涉及Python針對(duì)列表的合并、遍歷、判斷、追加、排序等操作技巧,需要的朋友可以參考下2018-02-02python和shell實(shí)現(xiàn)的校驗(yàn)IP地址合法性腳本分享
這篇文章主要介紹了python和shell實(shí)現(xiàn)的校驗(yàn)IP地址合法性腳本分享,每個(gè)腳本配有執(zhí)行效果圖,需要的朋友可以參考下2014-10-10Python 網(wǎng)絡(luò)編程之TCP客戶端/服務(wù)端功能示例【基于socket套接字】
這篇文章主要介紹了Python 網(wǎng)絡(luò)編程之TCP客戶端/服務(wù)端功能,結(jié)合實(shí)例形式分析了Python使用socket套接字實(shí)現(xiàn)TCP協(xié)議下的客戶端與服務(wù)器端數(shù)據(jù)傳輸操作技巧,需要的朋友可以參考下2019-10-10Python實(shí)現(xiàn)UDP與TCP通信的示例詳解
UDP是一種無(wú)連接的、不可靠的傳輸協(xié)議;TCP是一種可靠的、面向連接的傳輸協(xié)議。這篇文章主要介紹了Python實(shí)現(xiàn)UDP與TCP通信的方法,需要的可以參考一下2023-03-03