logo头像
Snippet 博客主题

获取小程序的openid与unionid

需要发布的小程序基本都要用到openid,这里保存一下自己的代码。
一种是不需要服务器的,通过微信提供的接口简单获取openid;一种是有服务器的情况下,获取openid和一些加密的信息,如unionid。

简单获取openid

这里的简单获取,是指调试的时候可以使用,正常的情况应该是通过服务器来获取
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
wx.login({
success: function (res) {
var code = res.code; // 复制给变量就可以打印了,醉了
if (res.code) {
wx.getUserInfo({
success: function (res) {
// userInfo 只存储个人的基础数据
wx.setStorageSync('userInfo', res.userInfo);

// 只获取openid的话,自己就可以
that.getOpenid(code);
}
})
} else {
console.log('获取用户登录态失败!' + res.errMsg)
}
}
})

// 自己获取openid和session_key
// 微信提供的接口,其中appid和secret都是放在globalData中的
getOpenid: function (code) {
var that = this;
wx.request({
url: 'https://api.weixin.qq.com/sns/jscode2session?appid=' + that.globalData.appid + '&secret=' + that.globalData.secret + '&js_code=' + code + '&grant_type=authorization_code',
data: {},
method: 'GET',
success: function (res) {
var obj = {};
obj.openid = res.data.openid;
obj.expires_in = Date.now() + res.data.expires_in;
obj.session_key = res.data.session_key;
wx.setStorageSync('openid', obj.openid);// 存储openid
}
});
},

通过服务器获取openid和unionid

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
41
42
43
44
wx.login({
success: function (res) {
var code = res.code; // 复制给变量就可以打印了,醉了
if (res.code) {
wx.getUserInfo({
success: function (res) {
// userInfo 只存储个人的基础数据
wx.setStorageSync('userInfo', res.userInfo);

// 请求自己的服务器,解密用户信息 获取unionId等加密信息
wx.request({
url: url.host + '/decodeUserInfo',//自己的服务接口地址
method: 'POST',
header: {
'content-type': 'application/x-www-form-urlencoded'
},
data: {
encryptedData: res.encryptedData,
iv: res.iv,
code: code,
},
success: function (data) {
//4.解密成功后 获取自己服务器返回的结果
if (data.data.code == 200) {
console.log('解密成功');
var encryptInfo = data.data.data;

wx.setStorageSync('openid', encryptInfo.openId); // 单独存储openid
wx.setStorageSync('encryptInfo', encryptInfo); // 存储解密之后的数据
} else {
console.log('解密失败')
}
}
},
fail: function (res) {
console.log(res);
console.log('请求错误')
}
})
} else {
console.log('获取用户登录态失败!' + res.errMsg)
}
}
})

最后,可以把这个方法给暴露出来,让其他界面调用

1
2
3
4
5
6
7
8
9
// 给其他界面调用,用来获取用户信息,防止没有获取成功
getUserInfo: function () {
var that = this
var userInfo = wx.getStorageSync('userInfo') || {};
var openid = wx.getStorageSync('openid') || null;
if (!userInfo.nickName || !openid) {
that.getData(); // 将wx.login({}) 方法放入其中
}
}

其实获取unionid的方法主要在后台实现,需要根据微信提供的方法去解密,具体的解密文档可以参考以下内容: 微信小程序获取用户openid微信小程序联盟:微信小程序之获取并解密用户数据(获取openId、unionId)

评论系统未开启,无法评论!