微信小程序獲取手機號,java后台


獲取小程序的手機號,指的是獲取綁定用戶微信的手機號碼,細節什么的我就不多說了,官網說的很詳細了
官網:https://developers.weixin.qq.com/miniprogram/dev/framework/open-ability/getPhoneNumber.html
注意:目前該接口針對非個人開發者,且完成了認證的小程序開放(不包含海外主體)。

如果你的小程序是 個人開發的話,這個借口就沒用的哦

點擊:https://mp.weixin.qq.com/   可以登錄你的公眾平台去看一下
 

好了 開始上代碼了哦

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;
    }

好了,這個是最基本的操作,最后,我再給大家理一下流程

  1. 先調用微信登錄,在后台獲取session_key並且保存在后台,然后傳一個自定義標識到前端(也就是我上面用到的sessionId),這部其實可以在onload方法里面完成
  2. 前端那邊要有一個按鈕,讓用戶主動點擊授權
  3. 授權后,js獲取加密數據,做為參數和自定義標識傳給后台
  4. 后台接收到參數后,進行加密數據解密算法,最后取得手機號

需要注意的是,要先在點擊授權之前先進行小程序登錄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 com.sun.org.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;

 

<!-- https://mvnrepository.com/artifact/org.bouncycastle/bcprov-jdk15on -->
<dependency>
    <groupId>org.bouncycastle</groupId>
    <artifactId>bcprov-jdk15on</artifactId>
    <version>1.65</version>
</dependency>
    public static Object getPhoneNumber(String encryptedData, String session_key, String iv) {
        // 被加密的數據
        byte[] dataByte = Base64.getDecoder().decode(encryptedData);
        // 加密秘鑰
        byte[] keyByte = Base64.getDecoder().decode(session_key);
        // 偏移量
        byte[] ivByte = Base64.getDecoder().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;
    }
    public static void main(String[] args) {
        String encryptedDataEncode = "OkQySaxxYhum7REYI4frScaygjuetYww3r8pyRPmWPQ6f7JtBjyjBIM%2FPhECHEkOC8TMLVLVn3mFYPvD250Z6Zwzu3QdCrgbowkAzVZVg8koF1UqQQUj8MhA02N%2F7AS5vQbnzSMMS6WocRU92NETJc%2B6tQzRdCQ8vDLS35M2v7ineHHEpi4%2FwFwZ2qej3eewcIAoCXx1w4K2LbWk7e8%2BRA%3D%3D";
        String sessionKeyEncode = "Y4v5ivp06bDFFssPUIj2sw%3D%3D";
        String ivEncode = "hn9XpCFcVOPtFmUADdBprA%3D%3D";
        String encryptedData = URLDecoder.decode(encryptedDataEncode);
        String sessionKey = URLDecoder.decode(sessionKeyEncode);
        String iv = URLDecoder.decode(ivEncode);
        Object obj = StringUtil.getPhoneNumber(encryptedData,sessionKey,iv);
        String json = JSON.toJSONString(obj);
        System.out.println(json);
        //{"phoneNumber":"18800000000","watermark":{"appid":"wx2ba363fc4454f27c","timestamp":1586333901},"purePhoneNumber":"18800000000","countryCode":"86"}
    }

 


————————————————
版權聲明:本文為CSDN博主「仙_」的原創文章,遵循 CC 4.0 BY-SA 版權協議,轉載請附上原文出處鏈接及本聲明。
原文鏈接:https://blog.csdn.net/qq_36466653/java/article/details/83374485


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM