小程序授权获取手机号

这是小程序授权获取手机号的步骤

第一步: wx.login---> 获取登录凭着(code)
第二步:将code发送到后端--->后端用code换session_key和openid
第三步:小程序调getPhoneNumber--->将encryptedData和iv传给后台
第四步:后台进行解密得到json--->进而获取到手机号

第一步:获取登录凭证code

这个code码是使用小程序登录接口完成后取的,这个wx.request()请求是为了把code发送到后端,后端用code换取session_key和openid。

//获取手机号前先获取openid和session_key
wx.login({
    success: function (res) {
      if (res.code) { //使用小程序登录接口完成后端用户登录
        wx.request({
          url: app.d.hostUrl + 'getOpenId',//你自己api接口的路径
          data: {
            code: res.code,
            appid: "你的小程序AppID",
            secret: "你的小程序secret",
          },
          success: function (res) {
            //把openid保存到缓存里
            wx.setStorageSync("openid", res.openid);
            wx.setStorageSync("session_key", res.session_key);
          }
        })
      } else {
        console.log('获取用户登录态失败!' + res.errMsg)
      }
    }

前端已经把获取openid和session_key需要的参数传给后端了,接下来就是后端的事了

第二步:后端用code换session_key和openid
//获取微信openId,
    public function getOpenId($dataArr){
        $retArr["ret"] = array("retCod" => "0", "retMsg" => "get openId  is success!");
        $code = $dataArr['code'];
        $appid = $dataArr['appid'];
        $secret = $dataArr['secret']; 
        $api = "https://api.weixin.qq.com/sns/jscode2session?appid=".$appid."&secret=".$secret."&js_code=".$code."&grant_type=authorization_code";
        $str = $this->doCurl($api);
        $str = json_decode($str,true);
        $retArr['data']['openid']= $str['openid'];
        $retArr['data']['session_key']= $str['session_key'] ;
        return $retArr;
    }
   //处理接口请求
    public function doCurl($url)
    {
        $curl = curl_init();
        // 使用curl_setopt()设置要获取的URL地址
        curl_setopt($curl, CURLOPT_URL, $url);
        // 设置是否输出header
        curl_setopt($curl, CURLOPT_HEADER, false);
        // 设置是否输出结果
        curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
        // 设置是否检查服务器端的证书
        curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, false);
        // 使用curl_exec()将CURL返回的结果转换成正常数据并保存到一个变量
        $data = curl_exec($curl);
        // 使用 curl_close() 关闭CURL会话
        curl_close($curl);
        return  $data;//json_decode($data);
    }

这样,前端success就能拿到openid和session_key了,现在,我们要在后端通过php,用session_key和openid来解密获取手机号码

第三步:调用getPhoneNumber,将encryptedData和iv传给后台

那现在(wxml)需要有一个按钮触发,点了那个按钮就能获取手机号码了

<button class='bottom' 
            type='primary' 
            open-type="getPhoneNumber" 
            lang="zh_CN"                                                    
           bindgetphonenumber="bindGetPhoneNumber">微信登录授权
</button>

//点击获取用户手机号按钮,这样手机号就获取到了
  bindGetPhoneNumber: function (e) {
    if (e.detail.errMsg== "getPhoneNumber:ok"){
        wx.showLoading({
          title: '授权登录中...',
        })
        var that = this;
        var detail = e.detail;
        var iv = detail.iv;
        var encryptedData = detail.encryptedData;
        var appid = app.globalData.appid;
        var userInfo = app.globalData.userInfo;
        var session_key = userInfo.session_key;
        allApi.getUserMobile({
          uid: "",
          v: app.globalData.v,
          imei: app.globalData.imei,
          sid: "",
          sign: "",
          appKey: app.globalData.appKey,
          src: app.globalData.src,
          r: app.globalData.r,
          city_id: app.globalData.city_id,
          city_name: app.globalData.city_name,
          data: { "appid": appid,
                  "session_key": session_key,             
                  "encryptedData": encryptedData,
                  "iv": iv },
       })
      .then((res) => {
        if (res.data.ret.retCod == 0) {
          wx.hideLoading();
          var mobile = res.data.data.mobile;
          var userInfo = that.data.userInfo;
          userInfo.mobile = mobile;
          wx.setStorageSync("wxUserInfo", userInfo);
          app.globalData.userInfo = userInfo;
          that.setData({
            'mobile': mobile,
            'isAuth': false,//改为不需要授权
            'userInfo': userInfo,
          })
          that.addUserMobile();
        }else{
          wx.showLoading({
            title: '请求超时,请重试',
          })
          setTimeout(this.hideLoadTip, 2000);
        }

      }).catch(function (error) {
        wx.hideLoading()
        wx.showToast({ icon: "none", title: "授权失败", duration: 1000 })
      })
    }
},
第四步:通过传参appid、session_key、encryptedData、iv解密获取手机号

因为涉及到解密手机号,所以先看下官方文档
小程序开发文档流程
https://developers.weixin.qq.com/miniprogram/dev/framework/open-ability/signature.html

下载解密文件.png

这个官方的demo文件很简单,大家可以根据自己的业务需求是更改


image.png
 public function getUserMobile($dataArr) {
    $retArr["ret"] = array("retCod" => "0", "retMsg" => "get wx user mobile is success!");
    $appid = $dataArr['appid'];
    $sessionKey = $dataArr['session_key'];
    $encryptedData = $dataArr['encryptedData'];
    $iv = $dataArr['iv'];
    //WxBizDataCrypt该类是官方提供的那个
    $pc = new WxBizDataCrypt($appid, $sessionKey);
    $errCode = $pc->decryptData($encryptedData, $iv, $data);
    if ($errCode == 0) {
          $phone = json_decode($data)->phoneNumber;
        $retArr['data']['mobile']= $phone;
    } else {
        $retArr["ret"] = array("retCod" => "-1", "retMsg" => "get wx user info  is fail!");
    }
    return $retArr;
}
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,445评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,889评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,047评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,760评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,745评论 5 367
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,638评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,011评论 3 398
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,669评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,923评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,655评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,740评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,406评论 4 320
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,995评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,961评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,197评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,023评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,483评论 2 342

推荐阅读更多精彩内容