JAva解析微信ウィジェットが取得した携帯電話番号


私はとても好奇心があって、javaは最も火の言語の1つとして、微信の小さいプログラムの開発のドキュメントの中で意外にも小さいプログラムの携帯番号のjavaの実例を解析していません.のあまりコードを言わないで!!!
1.
WeChatウィジェットに基づいてドキュメントを開発するには、まずウィジェットで必要な3つのパラメータ:encryptedData,iv,sessionKeyを取得します.
2.この3つのパラメータをバックグラウンドに転送して解析を開始し、最後の解析の結果、携帯電話番号、区番号+携帯電話番号、区番号のいくつかのパラメータを含むjsonオブジェクトに変換します.
public JSONObject getPhoneNumber(String session_key, String encryptedData, String iv) {
    String session_key1=session_key.replace(" ","+");
    String encryptedData1=encryptedData.replace(" ","+");
    String iv1=iv.replace(" ","+");
    byte[] dataByte = Base64.decodeBase64(encryptedData1);
    byte[] keyByte = Base64.decodeBase64(session_key1);
    byte[] ivByte = Base64.decodeBase64(iv1);
    try {
        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","BC");
        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;
}

Ok、終わり、こんなに簡単です.時々異常を報告するかもしれませんが、大丈夫です.私の解決方法は:
インタフェース解析に失敗した場合、新しいログインプロセスから新しい3つのパラメータ(encryptedData,iv,sessionKey)を取得し、携帯電話番号を取得するインタフェースを削除する.
より良い解決策がある場合は、いつでも議論してください.