天天看點

微信小程式擷取使用者的openid

微信小程式中擷取使用者的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"
}