700字范文,内容丰富有趣,生活中的好帮手!
700字范文 > 微信小程序获取手机号 java后台

微信小程序获取手机号 java后台

时间:2022-09-02 05:17:16

相关推荐

微信小程序获取手机号 java后台

获取小程序的手机号,指的是获取绑定用户微信的手机号码,细节什么的我就不多说了,官网说的很详细了

官网:https://developers./miniprogram/dev/framework/open-ability/getPhoneNumber.html

注意:目前该接口针对非个人开发者,且完成了认证的小程序开放(不包含海外主体)。

如果你的小程序是个人开发的话,这个借口就没用的哦

点击:https://mp./ 可以登录你的公众平台去看一下

好了 开始上代码了哦

wxml文件

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

js文件

getPhoneNumber: function(e) {wx.request({url: 'localhost/Demo/getPhoneNumber', //这里就写上后台解析手机号的接口//这里的几个参数是获取授权后的加密数据,作为参数传递给后台就行了data: {encryptedData: e.detail.encryptedData,sessionId: sessionId, iv: e.detail.iv},method:'POST'header: {'content-type': 'application/x-www-form-urlencoded' // POST请求},success (res) {console.log(res.data)}}}

java后台

public Object getPhoneNumber(String encryptedData, String session_key, String iv) {// 被加密的数据byte[] dataByte = Base64.decode(encryptedData);// 加密秘钥byte[] keyByte = Base64.decode(session_key);// 偏移量byte[] ivByte = Base64.decode(iv);try {// 如果密钥不足16位,那么就补足. 这个if 中的内容很重要int base = 16;if (keyByte.length % base != 0) {int groups = keyByte.length / base + (keyByte.length % base != 0 ? 1 : 0);byte[] temp = new byte[groups * base];Arrays.fill(temp, (byte) 0);System.arraycopy(keyByte, 0, temp, 0, keyByte.length);keyByte = temp;}// 初始化Security.addProvider(new BouncyCastleProvider());Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5Padding");SecretKeySpec spec = new SecretKeySpec(keyByte, "AES");AlgorithmParameters parameters = AlgorithmParameters.getInstance("AES");parameters.init(new IvParameterSpec(ivByte));cipher.init(Cipher.DECRYPT_MODE, spec, parameters);// 初始化byte[] resultByte = cipher.doFinal(dataByte);if (null != resultByte && resultByte.length > 0) {String result = new String(resultByte, "UTF-8");return JSONObject.parseObject(result);}} catch (Exception e) {e.printStackTrace();}return null;}

好了,这个是最基本的操作,最后,我再给大家理一下流程

先调用微信登录,在后台获取session_key并且保存在后台,然后传一个自定义标识到前端(也就是我上面用到的sessionId),这部其实可以在onload方法里面完成

前端那边要有一个按钮,让用户主动点击授权

授权后,js获取加密数据,做为参数和自定义标识传给后台

后台接收到参数后,进行加密数据解密算法,最后取得手机号

需要注意的是,要先在点击授权之前先进行小程序登录wx.login获取openid和session_key,然后再去点击授权,对,这个是正确的做法。我以前对这块也没研究过,然后很多同学跟我反应有bug,原因就是在点击授权之后再调用wx.login的话,那个时候加密数据已经出来了,但是session_key还没出来,而session_key是解密密钥,所以会导致解密信息出错。

最重要的一点还是

注意:目前该接口针对非个人开发者,且完成了认证的小程序开放(不包含海外主体)。

很多同学都问依赖jar包是哪些,我贴一下我的,大家可以自己去找哈

import java.util.Arrays;

import org.bouncycastle.jce.provider.BouncyCastleProvider;

import com.alibaba.fastjson.JSONObject;

import .apache.xerces.internal.impl.dv.util.Base64;

import javax.crypto.Cipher;

import javax.crypto.spec.IvParameterSpec;

import javax.crypto.spec.SecretKeySpec;

import java.security.AlgorithmParameters;

import java.security.Security;

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。