09_微信小程式之無感知重新整理token
09_微信小程式之無感知重新整理token
一.介面呼叫憑證token
微信小程式授權登入之後,會成生成token返回給客戶端,客戶端取得token之後,作為後續一系列介面的呼叫憑證,然後,伺服器返回給客戶端的token會有一個有效期,token一但過期,就會導致客戶端後續的介面呼叫失敗,因此,在呼叫介面之前,我們需要保證token是有效的,這樣才能保證客戶端的功能不會因為token過期而導致異常
二.微信授權登入、token合法性及有效性校驗
關於微信授權登入,可參考06_基於koa實現微信小程式授權登入流程
token合法性及有效性校驗
const Router = require('koa-router')
const router = new Router()
const { verifyToken } = require('../../../../utils/utils')
const User = require('../../../../model/user')
router.post('/api/v1/member/verify', async (ctx, next) => {
const token = ctx.request.header.token
//驗證token是否過期
const decoded = verifyToken(token)
const res = await User.findByOpenID(decoded.openid)
if(!res) {
//使用者不存在
throw new global.errors.UserNotFoundException()
}
ctx.body = {
code: 0,
msg: "token有效"
}
})
module.exports = router
const jwt = require('jsonwebtoken');
const verifyToken = function(token, secret) {
let decoded
try {
decoded = jwt.verify(token, 'com_aykj_gale');
} catch(error) {
let err = new global.errors.ForbiddenException()
if(error.name == 'TokenExpiredError') {
err.msg = 'token已過期'
err.errorCode = 10006
} else {
err.msg = 'token不合法'
err.errorCode = 10005
}
throw err
}
return decoded
}
/api/v1/member/code2token: 登入獲取token
/api/v1/member/register: 註冊
/api/v1/member/verify: token合法性及有效性校驗
/api/v1/member/member_index: 獲取使用者資訊,後續會基於此介面,實現token的無感知重新整理
三.微信小程式中請求介面
// /project_directory/config.js
const serverUrl = 'http://192.168.1.111:3000'
const config = {
code2token: `${serverUrl}/api/v1/member/code2token`,
register: `${serverUrl}/api/v1/member/register`,
verify: `${serverUrl}/api/v1/member/verify`,
memberIndex: `${serverUrl}/api/v1/member/member_index`
}
module.exports = config
// /project_directory/utils/http-service.js
class HttpService {
constructor(){}
get(url, params, headers) {
if(!headers) {
headers = {}
}
return this._request(url, 'GET', params, headers)
}
postJson(url, params, headers) {
if(!headers) {
headers = {}
}
headers['content-type'] = 'application/json'
return this._request(url, 'POST', params, headers)
}
postForm(url, params, headers) {
if(!headers) {
headers = {}
}
headers['content-type'] = 'application/x-www-form-urlencoded'
return this._request(url, 'POST', params, headers)
}
_request(url, method, params, headers) {
return new Promise((resolve, reject) => {
wx.request({
url: url,
method: method,
data: params,
header: headers,
complete: function(res) {
var errMsg = res.errMsg //request:ok;request:fail
if(errMsg != "request:ok") {
var reason = {
code: -1,
msg: "請求超時"
}
reject(reason)
} else {
var resData = res.data
var resDataCode = resData.code
if(resDataCode != undefined) {
if(resDataCode == 0) {
resolve(resData)
} else {
reject(resData)
}
} else {
var reason = {
code: -1,
msg: resData
}
reject(reason)
}
}
}
})
})
}
}
module.exports = HttpService
// /project_directory/http/request-center.js
import HttpService from "../utils/http-service"
import config from "../config"
const tokenKey = "token"
class RequestCenter {
constructor() {
this.httpService = new HttpService()
}
register(params, headers) {
return this.httpService.postJson(config.register, params, headers)
}
code2token(params, headers) {
return this.httpService.postJson(config.code2token, params, headers)
}
verifyToken(params, headers) {
return this.httpService.postJson(config.verify, params, headers)
}
memberIndex(params, headers) {
return this.httpService.postJson(config.memberIndex, params, headers)
}
wxLogin() {
return new Promise((resolve, reject) => {
wx.login({
complete: function(res) {
if(res && res.code) {
resolve(res.code)
} else {
reject({
code: -1,
msg: "wx.login 失敗"
})
}
}
})
})
}
}
const requestCenter = new RequestCenter()
module.exports = requestCenter
// /project_directory/pages/index/index.js
const app = getApp()
Page({
data: {
},
onLoad: async function(res) {
var token = wx.getStorageSync('token')
if(!token) {
wx.reLaunch({
url: '/pages/auth/auth',
})
} else {
var headers = {}
headers["token"] = wx.getStorageSync('token')
await getApp().global.requestCenter.memberIndex({}, headers)
}
}
})
四.無感知重新整理token
// /project_directory/http/request-center.js
import HttpService from "../utils/http-service"
import config from "../config"
const tokenKey = "token"
class RequestCenter {
...
memberIndex(params, headers) {
return this._verify(params, headers, () => {
return this.httpService.postJson(config.memberIndex, params, headers)
})
}
wxLogin() {
return new Promise((resolve, reject) => {
wx.login({
complete: function(res) {
if(res && res.code) {
resolve(res.code)
} else {
reject({
code: -1,
msg: "wx.login 失敗"
})
}
}
})
})
}
_verify(params, headers, fun) {
if(headers && headers[tokenKey]) {
return new Promise((resolve, reject) => {
//驗證token是否過期
this.verifyToken(params, headers).then((res) => {
//token未過期,繼續上一次請求
fun().then((res) => {
resolve(res)
}, (reason) => {
reject(reason)
})
}, (reason) => {
var code = reason.code
if(code == 10006) {
//token過期,重新整理token,繼續上一次請求
this.wxLogin().then((res) => {
this.code2token({code:res}, {}).then((res) => {
var token = res.token
wx.setStorageSync('token', token)
headers[tokenKey] = token
fun().then((res) => {
resolve(res)
}, (reason) => {
reject(reason)
})
}, (reason) => {
reject(reason)
})
}, (reason) => {
reject(reason)
})
} else {
reject(reason)
}
})
})
} else {
return fun()
}
}
}
const requestCenter = new RequestCenter()
module.exports = requestCenter
相關文章
- java微信小程式獲取ACCESS_TOKENJava微信小程式
- 微信小程式 webview 頁面重新整理微信小程式WebView
- 微信小程式-自定義下拉重新整理微信小程式
- 微信小程式之支付微信小程式
- 微信小程式開發之https從無到有微信小程式HTTP
- 微信小程式setData區域性重新整理列表微信小程式
- 微信小程式之wxss05微信小程式
- Appium 之測試微信小程式APP微信小程式
- Appium之測試微信小程式APP微信小程式
- 微信小程式之小白教程系列 第一篇 微信小程式 — Hello World微信小程式
- 微信小程式點贊、評論區域性重新整理微信小程式
- 微信小程式CSS之Flex佈局微信小程式CSSFlex
- 微信小程式微信小程式
- 微信小程式之:小程式接入高德地圖SDK微信小程式地圖
- 微信小程式之-NBA線上直播小程式開發微信小程式
- 微信小程式小技巧微信小程式
- angular 開發微信小程式及webview不重新整理問題Angular微信小程式WebView
- 微信小程式(1) 微信小程式TLS版本大於1.2微信小程式TLS
- 微信小程式之逆地址解析填坑微信小程式
- 微信小程式之登入態的探索微信小程式
- 微信小程式之文字向上滾動效果微信小程式
- 微信小程式之倒數計時元件微信小程式元件
- 微信小程式路由微信小程式路由
- 微信小程式開發系列四:微信小程式之控制器的初始化邏輯微信小程式
- 如何實現無感重新整理 Token
- Thinkphp微信行銷工具,微信小程式。PHP微信小程式
- 微信小程式之物流狀態時間軸微信小程式
- 微信小程式之裁剪圖片成圓形微信小程式
- 微信小程式之簡單開發操作(一)微信小程式
- 安卓微信小程式開發之“藍芽”安卓微信小程式藍芽
- 微信小程式實現軌跡回放,微信原生小程式,基於uniapp的小程式?微信小程式APP
- 微信小程式 demo 整理微信小程式
- 微信小程式 跳坑微信小程式
- 微信小程式學習微信小程式
- 微信小程式報錯微信小程式
- 微信小程式登入微信小程式
- 微信小程式總結微信小程式
- 微信小程式——商城篇微信小程式