注意1:
openid 并不能作为用户的唯一标识,openid 同一用户同一应用唯一,unionid 同一用户不同应用唯一,unionid 才是唯一标识,如果需要在多公众号、移动应用之间做用户共通,则需要用 unionid,否则若是单一产品,则也可以用 openid 作为唯一标识。
注意2:
虽然前端能拿到openid,但是发布上线的时候会无法过审,因为出于安全考虑,前端代码不允许暴露小程序appId和app secret(秘钥),所以此种方法不可取。
方法一: 后端操作
传 code 后端获取openid、unionid:
-
前端
调用 wx.login() 获取 临时登录凭证code ,并回传到开发者服务器。 - 后端调用 auth.code2Session 接口,换取 用户唯一标识 openid和 unionid 和 会话密钥 session_key。
后端注意:
- 会话密钥 session_key 是对用户数据进行 加密签名 的密钥。为了应用自身的数据安全,开发者服务器不应该把会话密钥下发到小程序,也不应该对外提供这个密钥。
- 临时登录凭证 code 只能使用一次
前端代码:
// 登录
wx.login({
success: res => {
wx.request({
url: 'url',// 后端接口地址
method: 'post',
header: {
'content-type': 'application/json' // 默认值
},
data: res.code, // 发送 res.code 到后台换取 openId, sessionKey, unionId
success (res) {
if (res.statusCode == 200) {
console.log(res);
} else {
console.log(res.errMsg)
}
},
fail(err) {
console.log(err);
}
})
}
})
方法2: 云开发
具体代码可以参考 超简单微信小程序获取用户openid