【微信小程序】:获取微信运动步数(30天)
усилの博客 2020/8/20 微信小程序
# 一、微信小程序获取微信运动步数
思路:
- 第一步先获取临时code(通过wx.login()api接口获取到)。
- 第二步获取会话密钥session_key https://api.weixin.qq.com/sns/jscode2session?appid=APPID&secret=SECRET&js_code=JSCODE&grant_type=authorization_code) secret appid在微信公众公众平台获取即可
代码实现获取code session_key
wx.login({
success: (result) => {
wx.cloud.callFunction({
name: 'yundong',
data: {
$url: 'getseesion',
code: result.code
}
})
1
2
3
4
5
6
7
8
9
2
3
4
5
6
7
8
9
云函数
//获取seesionkey
app.router('getseesion',async(ctx,next)=>{
console.log(event.code)
const URL=
`https://api.weixin.qq.com/sns/jscode2session?appid='您的小程序AppID'&secret='您的小程序appSecret'&js_code=${event.code}&grant_type=authorization_code`
const res=await rp.get(URL).then((res)=>{
console.log(res)
return res
})
ctx.body=res
})
1
2
3
4
5
6
7
8
9
10
11
2
3
4
5
6
7
8
9
10
11
返回数据
因为 session_key有期限,所以一段时间后需要判断 session_key是否已经过期
- 第三步调用 wx.getWeRunData()api接口方法获取微信运动返回数据
wx.getWeRunData({
success: (result) => {
const encryptedData = result.encryptedData
const iv = result.iv
const cloudID = result.cloudID
const appid = '您的小程序AppID'
const secret = '您的小程序appSecret'
//对数据进行解密(需要下载解密库并导入)
var pc = new WXBizDataCrypt(appid, session_key)
var data = pc.decryptData(encryptedData, iv)
console.log( data)
}
1
2
3
4
5
6
7
8
9
10
11
12
13
2
3
4
5
6
7
8
9
10
11
12
13
wx.getWeRunData()返回的数据 解密后的数据 将时间戳转化为时间
let date=new Date(data.stepInfoList[29].timestamp*1000)
console.log(date.getFullYear()+"-"+(date.getMonth()+1)+"-"+date.getDate()+"步数"+data.stepInfoList[29].step)
1
2
2
解密代码
//需要下载库(下面有下载链接,建议并将其放在该项目与RdWXBizDataCrypt.js同级目录)
var Crypto = require('cryptojs-master/cryptojs.js').Crypto;
var app = getApp();
function RdWXBizDataCrypt(appId, sessionKey) {
this.appId = appId
this.sessionKey = sessionKey
}
RdWXBizDataCrypt.prototype.decryptData = function (encryptedData, iv) {
// base64 decode :使用 CryptoJS 中 Crypto.util.base64ToBytes()进行 base64解码
var encryptedData = Crypto.util.base64ToBytes(encryptedData)
var key = Crypto.util.base64ToBytes(this.sessionKey);
var iv = Crypto.util.base64ToBytes(iv);
// 对称解密使用的算法为 AES-128-CBC,数据采用PKCS#7填充
var mode = new Crypto.mode.CBC(Crypto.pad.pkcs7);
try {
// 解密
var bytes = Crypto.AES.decrypt(encryptedData, key, {
asBpytes:true,
iv: iv,
mode: mode
});
var decryptResult = JSON.parse(bytes);
} catch (err) {
console.log(err)
}
if (decryptResult.watermark.appid !== this.appId) {
console.log(err)
}
return decryptResult
}
module.exports = RdWXBizDataCrypt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40