获取微信绑定的手机号

小程序中有很多地方都会用到注册用户信息的地方,用户需要填写手机号等,有了这个组件可以快速获取微信绑定手机号码,无须用户填写。

1.getPhoneNumber这个组件通过button来实现(别的标签无效)。将button中的open-type=“getPhoneNumber”,并且绑定bindgetphonenumber事件获取回调。

<button open-type="getPhoneNumber"  bindgetphonenumber="getPhoneNumber"> 获取手机号码</button> 

这个组件之前必须先调用login接口,如果没有调用login点击button时会提示先调用login。


2.html:

 wx.login({
           success: function (res) {
           //   console.log(res);
                if (res.code) {
                    //发起网络请求
                    wx.request({
                  
                      url: ''
                      data: {
                          code: res.code
                      },
                        
                      success: function (response) {
                          console.log(response);
                          var openId = response.data.openid;
                          var session_key = response.data.session_key;
                          var app = getApp();                    
                          app.globalData.openid = openId;
                          app.globalData.session_key = session_key;
                          typeof cb == "function" && cb()

                      }
                   })
                } else {
                    console.log('获取用户登录态失败!' + res.errMsg)
                }
            }
        });

 

3.通过bindgetphonenumber绑定的事件来获取回调。回调的参数有三个,

errMsg:用户点击取消或授权的信息回调。

iv:加密算法的初始向量(如果用户没有同意授权则为undefined)。

encryptedData: 用户信息的加密数据(如果用户没有同意授权同样返回undefined)

getPhoneNumber: function(e) {   
    
   var that=this;
    var session_key=app.globalData.session_key;

    if (e.detail.errMsg == 'getPhoneNumber:fail user deny') {
      wx.showModal({
        title: '提示',
        showCancel: false,
        content: '未授权',
        success: function (res) { }
      })
    } else {
      

      wx.checkSession({
        success: function () {
          console.log(1);
         wx.request({
            url: 'https://m.xianmaogame.com/sd_idiom/xcx/getPhoneNumber/demo.php',
            data: {
              encryptedData:e.detail.encryptedData,
              iv:e.detail.iv,
              sessionKey:session_key
            },
            method: 'GET',
            success: function (res) {
              console.log('获取手机号码成功');
              console.log(res);
            }
          })
        },
        fail: function () {
          console.log(2);
          wx.login({
            success: function (res) {
              if (res.code) {
                //发起网络请求
                wx.request({
                  url: ''
                  data: {
                    code: res.code
                  },
                  success: function (response) {
                    var openId = response.data.openid;
                    var session_key = response.data.session_key  
                    wx.request({
                      url: '',
                      data: {
                        encryptedData: e.detail.encryptedData,
                        iv: e.detail.iv,
                        sessionKey: session_key
                      },
                      method: 'GET',
                      success: function (res) {
                        console.log('获取手机号码成功');
                        console.log(res);
                      }
                    })
                  }
                })
              } else {
                console.log('获取用户登录态失败!' + res.errMsg)
              }
            }
          });      
        }
      })
    }

    
  } 

 

4.最后我们需要根据自己的业务逻辑来进行处理,如果用户不同意授权的话可能我们会有一个让他手动输入的界面,如果不是强制获取手机号的话可以直接跳转页面进行下一步。(用户不同意授权errMsg返回‘getPhoneNumber:fail user deny’)
5.用户同意授权,我们可以根据login时获取到的code来通过后台以及微信处理拿到session_key,最后通过app_id,session_key,iv,encryptedData(用户同意授权errMsg返回‘getPhoneNumber:ok’)

6.解密的方法可以去微信官方开发文档查看,有很详细说明。
原文:https://blog.csdn.net/weixin_38984353/article/details/80484951

A: 首先,要使用微信的登录能力,需要注册并开通微信开放平台。具体可以参考微信开放平台的文档。 其次,在开发者工具中创建一个小程序,获取到小程序的 appID。 然后,在小程序中引入开放能力模块,调用 wx.login 接口获取登录凭证 code。 在获取到 code 后,可以通过微信提供的云开发服务或者自行搭建后台服务器,调用微信的接口换取用户手机号。 下面是一个通过云开发服务获取手机号的例子: ```java import com.tencent.cloud.CosStsClient; import com.tencent.cloud.auth.Credential; import com.tencent.cloud.auth.Credentials; import com.tencent.cloud.auth.ShortTimeCredential; import com.tencent.cloud.CosXmlService; import com.tencent.cloud.CosXmlServiceConfig; import com.tencent.cloud.CosXmlServiceException; import com.tencent.cloud.auth.ScopeLimitCredentialProvider; import com.tencent.cloud.CosXmlSignSourceProvider; import com.tencent.cloud.QCloudSignSourceProvider; import com.tencent.cloud.CosXmlSignSourceProvider.GetSignSourceType; import com.tencent.qcloud.core.auth.COSXmlSignSourceProvider; import com.tencent.qcloud.core.auth.ShortTimeCredentialProvider; import java.util.LinkedList; import java.util.List; public class WeChat { public static void main(String[] args) throws Exception { String appId = "你的小程序的appID"; String appSecret = "你的小程序的appSecret"; String jsCode = "获取到的登录凭证code"; String sessionKey = getSessionKey(appId, appSecret, jsCode); String encryptedData = "获取到的encryptedData"; String iv = "获取到的iv"; String phoneNumber = getPhoneNumber(appId, sessionKey, encryptedData, iv); System.out.println("用户绑定手机号为:" + phoneNumber); } public static String getSessionKey(String appId, String appSecret, String jsCode) throws Exception { String url = "https://api.weixin.qq.com/sns/jscode2session?appid=" + appId + "&secret=" + appSecret + "&js_code=" + jsCode + "&grant_type=authorization_code"; String response = HttpUtils.sendGet(url); JSONObject jsonObject = JSONObject.parseObject(response); String sessionKey = jsonObject.getString("session_key"); return sessionKey; } public static String getPhoneNumber(String appId, String sessionKey, String encryptedData, String iv) throws Exception { String appIdKey = appId + "_session_key"; String appSecretKey = appId + "_session_secret"; String bucketName = "default-bucket-name"; String regionName = "region"; String secretId = "secretId"; String secretKey = "secretKey"; String token = ""; long durationSeconds = 1800; // 创建临时密钥 Credential cred = new Credential(secretId, secretKey); ScopeLimitCredentialProvider scopeLimitCredentialProvider = new ScopeLimitCredentialProvider(new ShortTimeCredentialProvider(cred, durationSeconds), "selected resource regionName", "selected resource bucketName", "selected resource prefix"); LinkedList<String> headers = new LinkedList<String>(); headers.add("host"); headers.add("content-type"); CosStsClient client = new CosStsClient(scopeLimitCredentialProvider); JSONObject credentials = client.getCredential(headers); String token = credentials.getString("sessionToken"); Credentials cred = new Credentials(credentials.getLong("startTime"), credentials.getLong("expiredTime"), credentials.getString("tmpSecretId"), credentials.getString("tmpSecretKey"), token); // 创建 CosXmlServiceConfig 对象,根据个人需求修改默认的配置参数 CosXmlServiceConfig serviceConfig = new CosXmlServiceConfig.Builder() .setAppidAndRegion(appId, regionName) .setDebuggable(true) .builder(); // 创建 CosXmlService 对象,实现获取短期证书的请求签名 CosXmlService cosXmlService = new CosXmlService(context, serviceConfig, new GetSignSourceType() { @Override public QCloudSignSourceProvider getSourceProvider() { return new CosXmlSignSourceProvider(cred); } }); byte[] sessionKeyByte = Base64.decode(sessionKey, Base64.DEFAULT); byte[] encryptedDataByte = Base64.decode(encryptedData, Base64.DEFAULT); byte[] ivByte = Base64.decode(iv, Base64.DEFAULT); // AES解密 Cipher cipher = Cipher.getInstance("AES/CBC/PKCS7Padding"); SecretKeySpec keySpec = new SecretKeySpec(sessionKeyByte, "AES"); IvParameterSpec ivSpec = new IvParameterSpec(ivByte); cipher.init(Cipher.DECRYPT_MODE, keySpec, ivSpec); byte[] dataByte = cipher.doFinal(encryptedDataByte); String data = new String(dataByte, "UTF-8"); JSONObject jsonObject = JSONObject.parseObject(data); String phoneNumber = jsonObject.getString("phoneNumber"); return phoneNumber; } } ``` 需要注意的是,在调用云开发服务时,需要引入对应的 SDK 依赖。具体可以参考腾讯云 COSXML SDK 的文档。 另外,由于微信的登录接口比较敏感,开发者在开发时需要注意保护用户的隐私信息。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值