小程序開(kāi)發(fā)之獲取用戶信息實(shí)現(xiàn)方法
我們?cè)谶M(jìn)入小程序時(shí),會(huì)有一個(gè)彈窗是獲取你的信息授權(quán),那么小程序是如何獲取用戶信息的,下面從開(kāi)發(fā)者角度出發(fā)說(shuō)說(shuō)小程序是如何獲取用戶信息的?

有兩種獲取用戶信息的方案。
1、不包含敏感信息openId 的json對(duì)象(包含:nickname、avatarUrl等基本信息)
2、包含敏感信息openId的基本信息。
第一種獲取方案
1、首先調(diào)用wx.login()接口 讓用戶授權(quán)驗(yàn)證,也就是我們?nèi)庋塾^察到的,你是否對(duì)xxxxx授權(quán)這種信息。
2、用戶成功授權(quán)后,調(diào)用wx.getUserInfo() 接口獲取用戶信息。
完整代碼如下:
wx.login({
success:function(){
wx.getUserInfo({
success:function(res){
var simpleUser = res.userInfo;
console.log(simpleUser.nickName);
}
});
}
});
第二種比較復(fù)雜了,需要與后臺(tái)進(jìn)行交互才能獲得userInfo,但是這種方案獲得的數(shù)據(jù)是完整的(包含openId)。
1、調(diào)用wx.login()接口 授權(quán) 在success 成功函數(shù)的參數(shù)中包含code。
2、調(diào)用wx.getUserInfo()接口success 函數(shù)中包含encryptedData、iv
3、將上述參數(shù)傳給后臺(tái)解析,生成userInfo
代碼如下
js
var request = require("../../utils/request.js");
wx.login({
success:function(res_login){
if(res_login.code)
{
wx.getUserInfo({
withCredentials:true,
success:function(res_user){
var requestUrl = "/getUserApi/xxx.php";
var jsonData = {
code:res_login.code,
encryptedData:res_user.encryptedData,
iv:res_user.iv
};
request.httpsPostRequest(requestUrl,jsonData,function(res){
console.log(res.openId);
});
}
})
}
}
})
后臺(tái)解析
/**
* 獲取粉絲信息
* 其中的參數(shù)就是前端傳遞過(guò)來(lái)的
*/
public function wxUserInfo($code,$encryptedData,$iv)
{
$apiUrl = "https://api.weixin.qq.com/sns/jscode2session?appid={$this->wxConfig['appid']}&secret={$this->wxConfig['appsecret']}&js_code={$code}&grant_type=authorization_code";
$apiData = json_decode(curlHttp($apiUrl,true),true);
if(!isset($apiData['session_key']))
{
echoJson(array(
"code" => 102,
"msg" => "curl error"
),true);
}
$userInfo = getUserInfo($this->wxConfig['appid'],$apiData['session_key'],$encryptedData,$iv);
if(!$userInfo)
{
echoJson(array(
"code" => 105,
"msg" => "userInfo not"
));
}
//$userInfo = json_decode($userInfo,true);
//載入用戶服務(wù)

立即掃碼關(guān)注

多門(mén)店/直營(yíng)/加盟連鎖管理系統(tǒng)