微信小程式中擷取使用者的openid的方式有兩種:
方法一:
先擷取使用者資訊(wx.getUserInfo),然後将傳回的使用者資訊中包含openid的敏感資訊解密得到使用者的openid一種是先擷取使用者資訊,然後将傳回的使用者資訊中包含openid的敏感資訊解密得到使用者的openid,這種方法擷取使用者openid比較麻煩,還涉及到資料解密,而且如果使用者拒絕授權,則擷取不到。這裡不細說此方法, 詳見文檔。
方法二:
先登入(wx.login)擷取使用者登入憑證(code),然後拿這個code當參數調用接口,通過後端擷取到使用者的openid。
小程式端代碼如下:
//app.js
App({
onLaunch: function() {
wx.login({
success: function(res) {
if (res.code) {
//發起網絡請求
wx.request({
url: 'https://test.com/onLogin',
data: {
code: res.code
}
})
} else {
console.log('擷取使用者登入态失敗!' + res.errMsg)
}
}
});
}
})
後端擷取資料方法如下:
//擷取使用者openid
function getopenid(){
$js_code = I('post.code');
if(empty($js_code)) return array('status'=>0,'info'=>'缺少js_code');
$appid = 'xxxxxxxxxxxxx';
$appsecret = 'xxxxxxxxxxxxxxxxxxxxxx';
$curl = 'https://api.weixin.qq.com/sns/jscode2session?appid=%s&secret=%s&js_code=%s&grant_type=authorization_code';
$curl = sprintf($curl,$appid,$appsecret,$js_code);
$result = request($curl);
return array('status'=>1,'info'=>json_decode($result,true));
}
資料傳回說明
//正常傳回的JSON資料包
{
"openid": "OPENID",
"session_key": "SESSIONKEY",
"unionid": "UNIONID"
}
//錯誤時傳回JSON資料包(示例為Code無效)
{
"errcode": 40029,
"errmsg": "invalid code"
}