python代码实现小程序登录流程时序总结
作者:Jeff的技术栈 时间:2022-10-16 17:30:14
官方文档
https://developers.weixin.qq.com/miniprogram/dev/framework/open-ability/login.html
小程序登录
小程序可以通过微信官方提供的登录能力方便地获取微信提供的用户身份标识,快速建立小程序内的用户体系。
登录流程时序
说明:
调用wx.login()获取临时登录凭证code,并回传到开发者服务器。
调用auth.code2Session接口,换取用户唯一标识 OpenID和会话密钥 session_key。
之后开发者服务器可以根据用户标识来生成自定义登录态,用于后续业务逻辑中前后端交互时识别用户身份。
注意:
会话密钥
session_key
是对用户数据进行加密签名的密钥。为了应用自身的数据安全,开发者服务器不应该把会话密钥下发到小程序,也不应该对外提供这个密钥。临时登录凭证 code 只能使用一次
小程序的登录总结
1 小程序端执行wx.login()获取code
2 将1中的code发送到后端,后端调用auth.code2Session这个接口,得到openid和session_key
3 自定义登入状态,我们生成一个key与openid和session_key相绑定。把key返回到小程序中
4 小程序端保存,然后下次请求需要登入的接口的时候,把key带上。
案例
# app.js的onLaunch中 因为登录是用户感觉不到的
App({
onLaunch: function () {
let that = this
// 登录
wx.login({
success: res => {
// 发送 res.code 到后台换取 openId, sessionKey, unionId
console.log(res.code) //拿到code
wx.request({
url:that.globalData.baseurl+"/login/",
data:{'code':res.code},
method:'POST',
success(e){
console.log(e.data)
// wx.setStorageSync("token", e.data.data.token)
}
})
}
}),
globalData: {
userInfo: null,
baseurl:"http://127.0.0.1:8000"
}
# dango后台中
# urls.py 路由中
path('login/', user.Login.as_view()),
# user.py中
from rest_framework.views import APIView
from rest_framework.response import Response
from api.wx import wx_login
import hashlib, time
from django.core.cache import cache
from api.models import Wxuser
class Login(APIView):
def post(self, request):
param = request.data
print(request.data)
if not param.get('code'):
return Response({"status": 1, "msg": '缺少参数'})
else:
code = param.get("code")
user_data = wx_login.get_login_info(code)
if user_data:
val = user_data['session_key'] + "&" + user_data['openid']
md5 = hashlib.md5()
md5.update(str(time.clock()).encode("utf-8"))
key = md5.hexdigest()
cache.set(key, val) # 放进内存redis库中,把key传给前端当token.下次前台带着key就能拿到val
has_user = Wxuser.objects.filter(openid=user_data['openid']).first() # 判断openid是否存在
if not has_user:
Wxuser.objects.create(openid=user_data['openid'])
return Response({
"status": 0,
"msg": "ok",
"data": {"token": key}
})
else:
return Response({"status": 2, "data": "无效的code"})
# models.py中:
from django.db import models
class Wxuser(models.Model):
id = models.AutoField(primary_key=True)
openid=models.CharField(max_length=255)
name = models.CharField(max_length=50)
avatar = models.CharField(max_length=200)
language = models.CharField(max_length=50)
province = models.CharField(max_length=50)
city = models.CharField(max_length=50)
country = models.CharField(max_length=50)
#gender = models.CharField(max_length=50)
creat_time = models.DateTimeField(auto_now_add=True)
update_time = models.DateTimeField(auto_now=True)
def __str__(self):
return self.openid
# settings.py中:自己注册的微信小程序信息
AppId=""
AppSecret=""
code2Session="https://api.weixin.qq.com/sns/jscode2session?appid={}&secret={}&js_code={}&grant_type=authorization_code"
# wx_login.py中:
from api.wx import settings
import requests
def get_login_info(code):
# 拼接路径
code_url = settings.code2Session.format(settings.AppId,settings.AppSecret,code)
response = requests.get(code_url) # 返回的是json数据
json_response = response.json() # 把json数据转换为字典
if json_response.get('session_key'):
return json_response
else:
return False
# cache缓存配置redis数据库
来源:https://www.cnblogs.com/guyouyin123/p/12482362.html
标签:python,小程序,登录时序
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
国内外字体网站(font)的整理
2007-10-14 09:58:00
![](https://img.aspxhome.com/file/UploadPic/200710/14/20071014104954729s.jpg)
关于DOM元素定位属性的深入学习
2008-04-02 11:46:00
网页制作,改变你的思维方式
2007-09-29 13:12:00
有效地使用 SQL事件探查器的提示和技巧
2009-01-15 13:39:00
判断 iframe 是否加载完成的完美方法
2009-09-24 13:35:00
ASP 判断是否有中文的代码
2011-04-15 11:07:00
python使用matplotlib:subplot绘制多个子图的示例
2021-01-26 18:13:08
![](https://img.aspxhome.com/file/2023/6/67816_0s.png)
asp获取远程网页的指定内容的实现代码
2011-02-16 10:41:00
em与px的区别以及em特点和应用
2008-11-11 12:03:00
下一代web:浏览器存储支持
2008-06-11 11:50:00
![](https://img.aspxhome.com/file/UploadPic/20086/11/2008611121332430s.gif)
有时间先后的翻页
2008-05-23 13:14:00
![](https://img.aspxhome.com/file/UploadPic/20085/23/2008523131914487s.gif)
匿名函数的写法
2010-01-06 13:32:00
python3+PyQt5使用数据库窗口视图
2023-03-08 10:44:26
![](https://img.aspxhome.com/file/2023/8/65858_0s.jpg)
SQL--JOIN之完全用法
2008-09-12 17:30:00
Python计算程序运行时间的方法
2023-08-09 09:53:50
oracle 树查询 语句
2009-07-17 18:20:00
javascript下兼容firefox选取textarea文本的代码
2013-08-30 02:05:16
windows7下调试ASP+ACCESS错误“未找到提供程序 该程序可能未正确安装”解决办法
2009-12-26 18:35:00
![](https://img.aspxhome.com/file/UploadPic/20101/11/20091119044705-94s.jpg)
asp开发Wap中的随笔
2008-05-21 12:56:00
javascript权威指南,学习笔记,之运算符号
2008-04-20 16:43:00