django实现登录注册(django与小程序实现登录验证功能的示例代码)
类别:脚本大全 浏览量:2282
时间:2022-01-28 01:31:12 django实现登录注册
django与小程序实现登录验证功能的示例代码之前用小程序做项目,因为后台使用的java开发,一切顺利,但切换成django做RESTful API接口时,在登陆注册时一直出现问题,网上搜索,借助一个网友的回答,找到了一种可行的解决方案,现记录如下。
具体流程
- 用户点击小程序页面上的登录授权认证
- 通过微信自带的认证获取code
- 调取登录接口,将code传入后台
- 后台拿到code调用微信接口获取openid等用户信息
- 后台将openid作为用户名,若存在则去校验用户信息,否则以此用户名创建新用户,密码随机生成
- 将校验结果或者创建信息返回给微信小程序端
- 根据返回的信息完成用户登录校验
django的用户权限认证
django有一套自己的完善用户模型,由于Django Auth自带的User模型字段有限,我们需要对其进行拓展(直接使用也可以)
|
nickname = models.CharField(verbose_name = u '昵称' ,max_length = 50 , blank = True ) user_avatar = models.ImageField(verbose_name = u '用户头像' , upload_to = 'image/%Y/%m/%d' , default = u 'image/default.png' , max_length = 500 ) user_email = models.EmailField(verbose_name = u '用户邮箱' ,max_length = 254 ) user_phone = models.BigIntegerField(verbose_name = u '手机号' , null = True ,blank = True ) user_birthday = models.DateField(verbose_name = u '出生日期' , default = timezone.now) user_sex = models.CharField(verbose_name = u '性别' ,max_length = 6 ,choices = (( 'male' , '男' ),( 'female' , '女' )),default = 'male' ) user_address = models.CharField(verbose_name = u '地址' ,max_length = 550 , blank = True ,null = True ) signature = models.CharField(verbose_name = u '个性签名' ,max_length = 550 , blank = True ,null = True ) |
用户接口序列化
|
from rest_framework import serializers class UserSerializer(serializers.ModelSerializer): class Meta: model = User fields = "__all__" |
登陆接口设计
|
class UserLogin(APIView): def post( self ,request): params = request.data userName = get_openid(params.get( 'code' )) userInfo = params.get( 'userinfo' ) try : user = User.objects.get(username = userName) except Exception as e: user = None if user: # 更新用户信息 user = User.objects.get(username = userName) else : #注册新用户 user = User.objects.create_user(username = userName,password = random_str( 10 )) #手动生成JWT # 手动生成token验证 jwt_payload_handler = api_settings.JWT_PAYLOAD_HANDLER jwt_encode_handler = api_settings.JWT_ENCODE_HANDLER payload = jwt_payload_handler(user) token = jwt_encode_handler(payload) ret = { 'code' : '00000' , 'msg' : None , 'data' :{}} ret[ 'msg' ] = '授权成功' ret[ 'data' ] = { 'token' : token, 'user_id' : user. id , 'nickname' : user.nickname } return JsonResponse(ret) |
解析code获取openid
|
class OpenidUtils( object ): def __init__( self , jscode): self .url = "https://api.weixin.qq.com/sns/jscode2session" self .appid = APPID self .secret = SECRET self .jscode = jscode # 前端传回的动态jscode def get_openid( self ): url = self .url + "?appid=" + self .appid + "&secret=" + self .secret + "&js_code=" + self .jscode + "&grant_type=authorization_code" r = requests.get(url) openid = r.json()[ 'openid' ] return openid |
小程序的登陆验证
具体登录流程可以查阅官方文档。
|
function getWXUserInfo() { const login = promisify(wx.login); const getUserInfo = promisify(wx.getUserInfo); return new Promise( function (resolve, reject) { _wxLogin(); function _wxLogin() { login().then( function (res) { getUserInfo().then( function (r) { let userInfo = r; userInfo.code = res.code; try { wx.setStorageSync( 'userInfo' , userInfo); } catch (e) { console.log(e) } if (userInfo && userInfo.code && userInfo.iv) { resolve(userInfo); } else { reject( 'wx login fail' ); } }). catch ( function (error) { reject(error); }); }). catch ( function (error) { reject(error); }); } }); } //登录接口验证 getWXUserInfo().then( function (data) { var result = { code: 0, data: {} }; var params = { 'code' :data.code, 'userinfo' :data.userInfo } wx.request({ url: '/api/login' , data: params, dataType: 'json' , method: 'POST' , success: function (response) { // 返回成功 if (response.data && response.data.code == '00000' ) { try { var resData = { custNo: data.user_id, nickname: data.nickname }; result.code = 0; result.data = resData; resolve(result); } catch (e) { console.warn(result) // 登录失败 result.code = 2; resolve(result); } } else { // 获取 customNum 失败 console.warn(result) result.code = 1; result.data = 'get customNum fail' ; resolve(result); } } }) } |
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持开心学习网。
原文链接:https://juejin.im/post/5c6b64bde51d457fa31e6a30
您可能感兴趣
- 微信小程序css使用技巧(微信小程序 CSS filter滤镜的使用示例详解)
- 小程序实现左右滑动窗口(小程序实现分页效果)
- 微信小程序贪吃蛇大作战(微信小程序实现贪吃蛇游戏)
- php开发微信小程序后台步骤流程(基于PHP实现微信小程序客服消息功能)
- dedecms织梦小程序插件(批量删除织梦dedecms文档搜索关键词的方法)
- thinkphp5开发小程序后台(PHP小程序支付功能完整版基于thinkPHP)
- 微信小程序映射设置(微信小程序虚拟列表的实现示例)
- 小程序开发计算方法(小程序实现简单的计算器)
- 微信小程序计数器代码(微信小程序实现计算器案例)
- 微信小程序可以用h5开发不(微信小程序webView嵌入H5的方法实例)
- 微信小程序开发模式(微信小程序引入Vant框架的全过程记录)
- 小程序实现购物车功能前后端代码(小程序实现购物车完整版)
- 小程序开发者代码工具(解析从小程序开发者工具源码看原理实现)
- 微信小程序日期选择器有星期天(微信小程序 滚动选择器时间日期详解及实例代码)
- 微信小程序实现自动定位(微信小程序实现锚点定位功能的方法实例)
- 微信小程序接口返回数据怎么弄(微信小程序页面返回传值的4种解决方案汇总)
- 如何追女孩子(如何追女孩子的技巧和方法)
- 是不是快乐全被你拿走了(而是你得到的)
- 世界上只有妈妈好(世界上只有妈妈好的歌词)
- 为什么现在社会越来越卷了(现在社会为什么发展那么快呢)
- 直播带货能赚到很多钱吗(直播带货能赚到很多钱吗现在)
- 做网红真的很能赚钱吗(做网红真的很能赚钱吗)
热门推荐
- angularjs使用指令(详解Angular路由动画及高阶动画函数)
- 织梦内容页编辑使用方法(织梦更新后如何去掉底部的织梦版权信息powered by dedecms)
- apache服务部署tomcat(详解Apache 和 Tomcat 整合原理、配置方案)
- css下填充代码(CSS学习笔记之常用Mixin封装实例代码)
- 虚拟主机windows和linux啥区别(Linux虚拟主机的好处有哪些?)
- python循环语句嵌套使用(Python分支语句与循环语句应用实例分析)
- docker无法访问宿主机ip(解决Mac下 docker 无法 ping 通宿主机的问题)
- dedecms调用点击数(织梦DEDECMS中显示复制地址,推荐给QQ/MSN上的好友的代码)
- ios键盘字符预览怎么关闭(详解通过focusout事件解决IOS键盘收起时界面不归位的问题)
- idea生成dockerfile(idea集合docker实现镜像打包一键部署)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9