佳木斯湛栽影视文化发展公司

主頁 > 知識庫 > Python Flask微信小程序登錄流程及登錄api實現(xiàn)代碼

Python Flask微信小程序登錄流程及登錄api實現(xiàn)代碼

熱門標簽:檢查注冊表項 使用U盤裝系統(tǒng) 網(wǎng)站建設 阿里云 智能手機 美圖手機 硅谷的囚徒呼叫中心 百度競價點擊價格的計算公式

一、先來看看效果

接口請求返回的數(shù)據(jù):


二、官方登錄流程圖


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

1、小程序端調(diào)用wx.login

2、判斷用戶是否授權

3、小程序端訪問 wx.getUserInfo

4、小程序端js代碼:

wx.login({
 success: resp => {
 // 發(fā)送 res.code 到后臺換取 openId, sessionKey, unionId
 console.log(resp);
 var that = this;
 // 獲取用戶信息
 wx.getSetting({
 success: res => {
 if (res.authSetting['scope.userInfo']) {
 // 已經(jīng)授權,可以直接調(diào)用 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 () { }//請求完成后執(zhí)行的函數(shù)
			 })
 }
 })
 } 
 }
 })
 }
 })

5、后端服務器訪問code2session,通過code2Session這個api接口來獲取真正需要的微信用戶的登錄態(tài)session_keyopenidunionid

6、后端服務器校驗用戶信息,對encryptedData 解密
微信小程序登錄后獲得session_key后,返回了encryptedData,iv的數(shù)據(jù),其中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)執(zhí)行pip3 install pycryptodome
(2)如果還是提示沒有該模塊,那就虛擬環(huán)境目錄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數(shù)據(jù)轉為字典
 appID = 'appID' # 開發(fā)者關于微信小程序的appID
 appSecret = 'appSecret' # 開發(fā)者關于微信小程序的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發(fā)起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)
 '''
 下面部分是通過判斷數(shù)據(jù)庫中用戶是否存在來確定添加或返回自定義登錄態(tài)(若用戶不存在則添加;若用戶存在,返回用戶信息)
 
 --------略略略略略略略略略-------------
 
 這部分我就省略啦,數(shù)據(jù)庫中對用戶進行操作
 '''
 
 return json.dumps
({
"code": 200, "msg": "登錄成功","userinfo":userinfo}, indent=4, sort_keys=True, default=str, ensure_ascii=False)

總結

到此這篇關于Python Flask微信小程序登錄詳解及登錄api實現(xiàn)的文章就介紹到這了,更多相關Python Flask微信小程序登錄詳解及登錄api實現(xiàn)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

標簽:湘潭 通遼 賀州 懷化 煙臺 山南 湖北 黃山

巨人網(wǎng)絡通訊聲明:本文標題《Python Flask微信小程序登錄流程及登錄api實現(xiàn)代碼》,本文關鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    东阿县| 石狮市| 海宁市| 河曲县| 垣曲县| 旅游| 邵阳市| 团风县| 怀柔区| 大关县| 辽中县| 玉溪市| 麦盖提县| 台前县| 财经| 区。| 五家渠市| 江都市| 睢宁县| 杭州市| 临猗县| 宿州市| 巴彦淖尔市| 调兵山市| 密山市| 宣武区| 宁海县| 清水河县| 波密县| 定安县| 虹口区| 汉沽区| 汉寿县| 正定县| 合江县| 阿图什市| 浦城县| 定南县| 静安区| 九台市| 邮箱|