【Python-Django后端】用户注册通用逻辑,用户名、手机号重名检测,注册成功后状态保持!!!
2018-07-28 13:49
489 查看
用户注册后端逻辑
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()方法介绍
- 状态保持:
-
将通过认证的用户的唯一标识信息(比如:用户ID)写入到当前session会话中
- login()方法:
-
Django用户认证系统提供了
login()
方法 - 封装了写入session的操作,帮助我们快速实现状态保持
-
login()位置:
django.contrib.auth.__init__.py
文件中login(request, user)
[/code]
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); }) }
相关文章推荐
- Django商城项目笔记No.7用户部分-注册接口-判断用户名和手机号是否存在
- js注册检测 用户名、密码、手机号、邮箱
- 用户在注册成功后,发送用户名和密码到其注册邮箱的方法 .
- 毕业设计(十)---用DWR实现 代替AJAX 用户注册检测用户名是否已经存在
- js注册检测 用户名、密码、手机号、邮箱等
- django项目培训站-22-验证码库的应用-用户密码django加密函数-用户注册逻辑
- jquery+ajax 根据输入生成用户名并检测用户重名
- 毕业设计(十)---用DWR实现 代替AJAX 用户注册检测用户名是否已经存在
- jQuery+Ajax+Mysql 检测用户名注册时是否重名
- python django 用户注册验证登录。。。
- jquery与php交互的ajax应用第一课:检测用户注册时用户名是否存在
- java在线聊天项目 客户端登陆窗口LoginDialog的注册用户功能 修改注册逻辑 增空用户名密码的反馈 增加showMessageDialog()提示框
- python判断用户注册中用户名是否包含非法字符
- Python通过Django实现用户注册和邮箱验证功能代码
- jquery与php交互的ajax应用第一课:检测用户注册时用户名是否存在
- jquery与php交互的ajax应用第一课:检测用户注册时用户名是否存在
- Asp.net下利用Jquery Ajax实现用户注册检测(验证用户名是否存)
- 用户注册-(包含验证码、是否阅览制度前按钮隐藏、检测用户名是否存在)
- Django 简易实现用户保持登录状态2月
- JDBC编程作业--登陆界面的实现(检测数据库中是否有用户名,并且可以注册用户)!