【Python-Django后端】用戶注冊通用邏輯,用戶名、手機號重名檢測,注冊成功后狀態保持!!!


用戶注冊后端邏輯

1. 接收參數

username = request.POST.get('username')
password = request.POST.get('password')
password2 = request.POST.get('password2')
mobile = request.POST.get('mobile')
allow = request.POST.get('allow')

 

2. 校驗參數

from django import http
import re

# 判斷參數是否齊全
if not all([username, password, password2, mobile, allow]):
    return http.HttpResponseBadRequest('缺少必傳參數')
# 判斷用戶名是否是5-20個字符
if not re.match(r'^[a-zA-Z0-9_]{5,20}$', username):
    return http.HttpResponseBadRequest('請輸入5-20個字符的用戶名')
# 判斷密碼是否是8-20個數字
if not re.match(r'^[0-9A-Za-z]{8,20}$', password):
    return http.HttpResponseBadRequest('請輸入8-20位的密碼')
# 判斷兩次密碼是否一致
if password != password2:
    return http.HttpResponseBadRequest('兩次輸入的密碼不一致')
# 判斷手機號是否合法
if not re.match(r'^1[3-9]\d{9}$', mobile):
    return http.HttpResponseBadRequest('請輸入正確的手機號碼')
# 判斷是否勾選用戶協議
if allow != 'on':
    return http.HttpResponseBadRequest('請勾選用戶協議')

 這里校驗的參數,前端已經校驗過,如果此時參數還是出錯,說明該請求是非正常渠道發送的,所以直接禁止掉。

3. 保存注冊數據

from django.db import DatabaseError

# 保存注冊數據
try:
    User.objects.create_user(username=username, password=password, mobile=mobile)
except DatabaseError:
    return render(request, 'register.html', {'register_errmsg': '注冊失敗'})

# 響應注冊結果
return http.HttpResponse('注冊成功,重定向到首頁')

  

示例:重定向

from django.shortcuts import redirect
from django.urls import reverse

# 響應注冊結果
return redirect(reverse('contents:index'))

  

狀態保持

1. login()方法介紹

  1. 狀態保持:
    • 將通過認證的用戶的唯一標識信息(比如:用戶ID)寫入到當前session會話中
  2. login()方法:
    • Django用戶認證系統提供了 login() 方法
    • 封裝了寫入session的操作,幫助我們快速實現狀態保持
  3. login()位置:

    • django.contrib.auth.__init__.py文件中

      login(request, user)

2. login()方法使用

# 保存注冊數據
try:
    user = User.objects.create_user(username=username, password=password, mobile=mobile)
except DatabaseError:
    return render(request, 'register.html', {'register_errmsg': '注冊失敗'})

# 實現狀態保持
login(request, user)

# 響應注冊結果
return redirect(reverse('contents:index'))

  

 

用戶名或手機號重復注冊邏輯:

1.請求方式

 

選項 方案
請求方法 GET
請求地址 /usernames/(?P<username>[a-zA-Z0-9_]{5,20})/count/

 

 

用戶名重復注冊后端邏輯(通過filter過濾是否有重名用戶,count返回0或1,0說明沒注冊過,手機號重復注冊邏輯相同)

from utils.response_code import RETCODE

class UsernameCountView(View):
    """判斷用戶名是否重復注冊"""

    def get(self, request, username):
        """
        :param request: 請求對象
        :param username: 用戶名
        :return: JSON
        """
        count = User.objects.filter(username=username).count()
        return http.JsonResponse({'code': RETCODE.OK, 'errmsg': 'OK', 'count': count})

  

 前端邏輯:

//檢測用戶名是否存在
if (this.error_username == false) {
    //拼接請求url
    let url = '/usernames/' + this.username + '/count/';
    axios.get(url,{
        responseType: 'json'
    })
        .then(response => {
            //請求成功的判斷
            if (response.data.count == 1) {
                this.error_username_message = '用戶名已存在';
                this.error_username = true;
            } else {
                this.error_username = false;
            }
        })
        .catch(error => {
            //請求失敗顯示錯誤
            console.log(error.response);
        })
}

  

 

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM