当前位置:   article > 正文

小程序获取用户手机号_getphonenumber

getphonenumber

通过获取用户手机号,可以省去很多操作,是比较常见的功能。

获取用户手机号码 分为以下几步:

第一点击页面获取授权按钮

第二获取用户授权参数

第三根据加解密算法解密手机号码

需要将 button 组件 open-type 的值设置为 getPhoneNumber,当用户点击并同意之后,可以通过 bindgetphonenumber 事件回调获取到微信服务器返回的加密数据, 然后在第三方服务端结合 session_key 以及 app_id 进行解密获取手机号。

<button open-type="getPhoneNumber" bindgetphonenumber="getPhoneNumber"></button>

getPhoneNumber是微信官方要求,获取用户手机号码授权

onGetPhoneNumber是回调函数,获取授权后会回调到该方法,也就是获取的电话号码就在这个函数的返回值里面。当然这个函数是自定义的,名字大家可以随便起,上面的getPhoneNumber可不能随便修改。

  1. onGetPhoneNumber(e) {
  2. var that = this;
  3. wx.login({
  4. success (res) {
  5. if (res.code) {
  6. console.log('步骤2获检查用户登录状态,获取用户电话号码!', res)
  7. wx.request({
  8. url: '这里写自己的接口',
  9. data: {code: res.code},
  10. success: function(res) {
  11. console.log("步骤三获取授权码,获取授权openid,session_key",res);
  12. var userphone=res.data.data;
  13. wx.setStorageSync('userphoneKey',userphone);
  14. //解密手机号
  15. var msg = e.detail.errMsg;
  16. var sessionID=wx.getStorageSync("userphoneKey").session_key;
  17. var encryptedData=e.detail.encryptedData;
  18. var iv=e.detail.iv;
  19. if (msg == 'getPhoneNumber:ok') {//这里表示获取授权成功
  20. wx.checkSession({
  21. success:function(){
  22. //这里进行请求服务端解密手机号
  23. that.deciyption(sessionID,encryptedData,iv);
  24. },
  25. fail:function(){
  26. // that.userlogin()
  27. }
  28. })
  29. }
  30. },fail:function(res){
  31. console.log("fail",res);
  32. }
  33. })
  34. } else {
  35. console.log('登录失败!' + res.errMsg)
  36. }
  37. }
  38. })

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/从前慢现在也慢/article/detail/284579
推荐阅读
相关标签
  

闽ICP备14008679号