Python Flask微信小程序登录流程及登录api实现代码

作者:Effortzjw 时间:2022-03-21 14:33:47 

一、先来看看效果

Python Flask微信小程序登录流程及登录api实现代码

接口请求返回的数据:

Python Flask微信小程序登录流程及登录api实现代码

二、官方登录流程图

Python Flask微信小程序登录流程及登录api实现代码

三、小程序登录流程梳理:

1、小程序端调用wx.login

2、判断用户是否授权

3、小程序端访问 wx.getUserInfo

4、小程序端js代码:


wx.login({
success: resp => {
// 发送 res.code 到后台换取 openId, sessionKey, unionId
console.log(resp);
var that = this;
// 获取用户信息
wx.getSetting({
success: res => {
if (res.authSetting['scope.userInfo']) {
// 已经授权,可以直接调用 getUserInfo 获取头像昵称,不会弹框
wx.getUserInfo({
success: userResult => {
var platUserInfoMap = {}
platUserInfoMap["encryptedData"] = userResult.encryptedData;
platUserInfoMap["iv"] = userResult.iv;
wx.request({
url: 'http://127.0.0.1:5000/user/wxlogin',
data: {
platCode: resp.code,
 platUserInfoMap: platUserInfoMap,
},
header: {
"Content-Type": "application/json"
},
method: 'POST',
dataType:'json',
success: function (res) {
console.log(res)
 wx.setStorageSync("userinfo", res.userinfo) //设置本地缓存
},
fail: function (err) { },//请求失败
complete: function () { }//请求完成后执行的函数
})
}
})
}
}
})
}
})

5、后端服务器访问code2session,通过code2Session这个api接口来获取真正需要的微信用户的登录态session_keyopenidunionid

6、后端服务器校验用户信息,对encryptedData 解密
微信小程序登录后获得session_key后,返回了encryptedData,iv的数据,其中encryptedData解密后包含了用户的信息,解密后的json格式如下:


{
"openId": "OPENID",
"nickName": "NICKNAME",
"gender": GENDER,
"city": "CITY",
"province": "PROVINCE",
"country": "COUNTRY",
"avatarUrl": "AVATARURL",
"unionId": "UNIONID",
"watermark":
{
"appid":"APPID",
"timestamp":TIMESTAMP
}
}

7、新建解密文件——WXBizDataCrypt.py


from Crypto.Cipher import AES这边一般会遇到ModuleNotFoundError:No module named "Crypto"错误
(1)执行pip3 install pycryptodome
(2)如果还是提示没有该模块,那就虚拟环境目录Lib—-site-package中查看是否有Crypto文件夹,这时你应该看到有crypto文件夹,将其重命名为Crypto即可


import base64
import json
from Crypto.Cipher import AES

class WXBizDataCrypt:
def __init__(self, appId, sessionKey):
self.appId = appId
self.sessionKey = sessionKey

def decrypt(self, encryptedData, iv):
# base64 decode
sessionKey = base64.b64decode(self.sessionKey)
encryptedData = base64.b64decode(encryptedData)
iv = base64.b64decode(iv)

cipher = AES.new(sessionKey, AES.MODE_CBC, iv)

decrypted = json.loads(self._unpad(cipher.decrypt(encryptedData)))

if decrypted['watermark']['appid'] != self.appId:
raise Exception('Invalid Buffer')

return decrypted

def _unpad(self, s):
return s[:-ord(s[len(s)-1:])]

8、Flask的/user/wxloginapi代码:


import json,requests
from WXBizDataCrypt import WXBizDataCrypt
from flask import Flask

@app.route('/user/wxlogin', methods=['GET','POST'])
def user_wxlogin():
data = json.loads(request.get_data().decode('utf-8')) # 将前端Json数据转为字典
appID = 'appID' # 开发者关于微信小程序的appID
appSecret = 'appSecret' # 开发者关于微信小程序的appSecret
code = data['platCode'] # 前端POST过来的微信临时登录凭证code
encryptedData = data['platUserInfoMap']['encryptedData']
iv = data['platUserInfoMap']['iv']
req_params = {
'appid': appID,
'secret': appSecret,
'js_code': code,
'grant_type': 'authorization_code'
}
wx_login_api = 'https://api.weixin.qq.com/sns/jscode2session'
response_data = requests.get(wx_login_api, params=req_params) # 向API发起GET请求
resData = response_data.json()
openid = resData ['openid'] # 得到用户关于当前小程序的OpenID
session_key = resData ['session_key'] # 得到用户关于当前小程序的会话密钥session_key

pc = WXBizDataCrypt(appID, session_key) #对用户信息进行解密
userinfo = pc.decrypt(encryptedData, iv) #获得用户信息
print(userinfo)
'''
下面部分是通过判断数据库中用户是否存在来确定添加或返回自定义登录态(若用户不存在则添加;若用户存在,返回用户信息)

--------略略略略略略略略略-------------

这部分我就省略啦,数据库中对用户进行操作
'''

return json.dumps
({
"code": 200, "msg": "登录成功","userinfo":userinfo}, indent=4, sort_keys=True, default=str, ensure_ascii=False)

来源:https://blog.csdn.net/qq_33966519/article/details/106545820

标签:Python,Flask,微信小程序,登录
0
投稿

猜你喜欢

  • 解决Vue watch里调用方法的坑

    2024-05-05 09:10:44
  • Dreamweaver MX 2004 试用心得

    2010-03-25 12:21:00
  • django haystack实现全文检索的示例代码

    2021-04-08 05:00:59
  • Python学习之异常中的finally使用详解

    2021-09-08 02:21:38
  • JS简单模拟触发按钮点击功能的方法

    2024-04-22 13:02:52
  • 优化MySQL数据库中的查询语句详解

    2024-01-21 06:17:06
  • mysql错误处理之ERROR 1665 (HY000)

    2024-01-21 12:16:54
  • sql server 交集,差集的用法详解

    2024-01-23 03:44:08
  • python人工智能tensorflow构建卷积神经网络CNN

    2023-01-09 21:49:10
  • 技术性击倒与抬杠

    2009-02-12 12:28:00
  • Python基于csv模块实现读取与写入csv数据的方法

    2023-04-12 23:14:34
  • python 接口_从协议到抽象基类详解

    2021-06-18 02:22:06
  • Python3简单实现串口通信的方法

    2022-03-10 03:39:53
  • vue-cli4.5.x快速搭建项目

    2024-04-27 15:52:18
  • Python实现字符串与数组相互转换功能示例

    2021-08-13 15:50:12
  • 关于pytest结合csv模块实现csv格式的数据驱动问题

    2023-01-11 20:40:03
  • Python中is与==的使用区别详解

    2023-10-15 04:08:21
  • 详解python 字符串和日期之间转换 StringAndDate

    2021-11-17 03:40:56
  • WEB2.0网页制作标准教程(11)不用表格的菜单

    2008-02-19 19:36:00
  • javascript实现炫酷的拖动分页

    2024-06-19 01:46:04
  • asp之家 网络编程 m.aspxhome.com