解密微信手机号报 last block incomplete in decryption

微信获取手机号解码问题,先上代码

 //解析电话号码
    public JSONObject getPhoneNumber(String session_key, String encryptedData, String iv) throws IOException {
        System.out.println(session_key);
        byte[] dataByte = org.bouncycastle.util.encoders.Base64.decode(encryptedData);
        // 加密秘钥
        byte[] keyByte = org.bouncycastle.util.encoders.Base64.decode(session_key);
        // 偏移量
        byte[] ivByte = org.bouncycastle.util.encoders.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/PKCS7Padding","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;
    }

请求方法

    @PostMapping(value = "getPhoneByWeChat")
    @ApiOperation("授权手机号")
    public Result getPhoneByWeChat(@RequestBody PhoneVo phoneVo){
        try{
            JSONObject obj= getPhoneNumber(phoneVo.getSessionKey(),phoneVo.getEncryptedData(),phoneVo.getIv());//解密电话号码
            return new Result(ResultStatusCode.PHONE_SUCCESS,obj);
        }catch (Exception e){
            e.printStackTrace();
            return new Result(ResultStatusCode.SYSTEM_ERR);
        }
    }

前端请求时一直报 last block incomplete in decryption,搞了半天都没找到原因,后来看到别人提到参数编码问题,后台设置请求参数原来是通过url传参,后来想到可能会参数编码问题,改成formater请求,解码成功。

记这次很大的一个坑!!!

发布了55 篇原创文章 · 获赞 6 · 访问量 3982

猜你喜欢

转载自blog.csdn.net/qq_40126996/article/details/103970397