国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發(fā) > JS > 正文

微信小程序開發(fā)之如何獲取用戶信息

2024-05-06 16:42:07
字體:
來源:轉載
供稿:網(wǎng)友

最近在研究微信小程序怎么玩的。接觸后發(fā)現(xiàn)好多的坑。

比如在瀏覽器中我們可以通過document.getElementById 獲取到頁面的DOM對象。而在微信小程序中是獲取不到DOM對象的。document.getElementById() 直接報錯 getElementById not function 我也是醉了。不支持這個好多有趣的功能不能實現(xiàn)了。
言歸正傳,我談下獲取用戶信息的感想。

有兩種獲取用戶信息的方案。
1、不包含敏感信息openId 的json對象(包含:nickname、avatarUrl等基本信息)
2、包含敏感信息openId的基本信息。

第一種獲取方案

1、首先調(diào)用wx.login()接口 讓用戶授權驗證,也就是我們?nèi)庋塾^察到的,你是否對xxxxx授權這種信息。
2、用戶成功授權后,調(diào)用wx.getUserInfo() 接口獲取用戶信息。

完整代碼如下

wx.login({  success:function(){    wx.getUserInfo({      success:function(res){        var simpleUser = res.userInfo;        console.log(simpleUser.nickName);      }    });  }});

第二種比較復雜了,需要與后臺進行交互才能獲得userInfo,但是這種方案獲得的數(shù)據(jù)是完整的(包含openId)。

1、調(diào)用wx.login()接口 授權 在success 成功函數(shù)的參數(shù)中包含code。
2、調(diào)用wx.getUserInfo()接口success 函數(shù)中包含encryptedData、iv
3、將上述參數(shù)傳給后臺解析,生成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);           });         }       })     }   } })

后臺解析

/** * 獲取粉絲信息 * 其中的參數(shù)就是前端傳遞過來的 */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);  //載入用戶服務  //$userService = load_service("User");  //$userService->checkUser($this->projectId,$userInfo);  echo $userInfo;  //微信響應的就是一個json數(shù)據(jù)}

getUserInfo function 其中wxBizDataCrypt.php 就是微信官方提供的素材包

curlHttp 函數(shù)是一個自定函數(shù) 該函數(shù)的源碼查看我的這篇文章curlHttp

//獲取粉絲信息function getUserInfo($appid,$sessionKey,$encryptedData,$iv){  require_once ROOTPATH . "/extends/wxUser/wxBizDataCrypt.php";  $data = array();  $pc = new WXBizDataCrypt($appid, $sessionKey);  $errCode = $pc->decryptData($encryptedData, $iv, $data );  if ($errCode == 0) {    return $data;  } else {    return false;  }}

自己寫的小工具 request.js

 

var app = getApp();//遠程請求var __httpsRequest = {  //http 請求  https_request : function(obj){    wx.request(obj);  },  //文件上傳  upload_request : function(dataSource){    wx.uploadFile(dataSource);  }};module.exports = {  //執(zhí)行異步請求get  httpsRequest:function(obj){    var jsonUrl = {};    jsonUrl.url = obj.url;    if(obj.header)jsonUrl.header=obj.header;    if(obj.type)      jsonUrl.method = obj.type;    else      jsonUrl.method="GET";    if(obj.data)jsonUrl.data = obj.data;    obj.dataType?(jsonUrl.dataType=obj.dataType):(jsonUrl.dataType="json");    jsonUrl.success = obj.success;    jsonUrl.data.projectId = app.globalData.projectId;    __httpsRequest.https_request(jsonUrl);  },  //get 請求  httpsGetRequest:function(req_url,req_obj,res_func)  {    var jsonUrl = {      url:app.globalData.host + req_url,      header:{"Content-Type":"application/json"},      dataType:"json",      method:"get",      success:function(res)      {        typeof res_func == "function" && res_func(res.data);      }    }    if(req_obj)    {      jsonUrl.data = req_obj;    }    jsonUrl.data.projectId = app.globalData.projectId;     __httpRequest.https_request(jsonUrl);  },  //post 請求  httpsPostRequest:function(req_url,req_obj,res_func)  {    var jsonUrl = {      url:app.globalData.host + req_url,      header:{"Content-Type":"application/x-www-form-urlencoded"},      dataType:"json",      method:"post",      success:function(res)      {        typeof res_func == "function" && res_func(res.data);      }    }    if(req_obj)    {      jsonUrl.data = req_obj;    }    jsonUrl.data.projectId = app.globalData.projectId;     __httpsRequest.https_request(jsonUrl);  },  //文件上傳  httpsUpload:function(uid,fileDataSource,res_func)  {    dataSource = {      url:app.globalData.host + req_url,      header:{        "Content-Type":"multipart/form-data"      },      dataType:"json",      formData  : {        "uid"  :  uid      },      filePath  : fileDataSource,      name    : "fileObj",      success:function(res){        typeof res_func == "function" && res_func(res);      }    }    __httpsRequest.upload_request(dataSource);  }};

app.globalData.host 就是域名地址如 https://xxxxx.com;

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網(wǎng)。


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 和林格尔县| 安塞县| 高台县| 周至县| 芜湖市| 宁强县| 庆元县| 股票| 静海县| 古交市| 依兰县| 剑河县| 唐河县| 双峰县| 通辽市| 崇信县| 刚察县| 昌平区| 闽清县| 罗定市| 渭源县| 万山特区| 奈曼旗| 若羌县| 阿勒泰市| 台中县| 佛坪县| 阿荣旗| 荣昌县| 荣成市| 项城市| 汪清县| 九寨沟县| 中阳县| 江津市| 正安县| 巨野县| 常熟市| 乌拉特后旗| 抚顺市| 津南区|