问答

php 如何实现 java 的解密方式

作者:admin 2021-05-13 我要评论

会PHP。还不会Java,奈何文档只有Java 代码demo public static String decode(String message, String privateKey) throws KsMerchantApiException { try { if (...

在说正事之前,我要推荐一个福利:你还在原价购买阿里云、腾讯云、华为云服务器吗?那太亏啦!来这里,新购、升级、续费都打折,能够为您省60%的钱呢!2核4G企业级云服务器低至69元/年,点击进去看看吧>>>)

会PHP。还不会Java,奈何文档只有Java 代码demo

public static String decode(String message, String privateKey) throws KsMerchantApiException {
        try {
            if (KsStringUtils.isBlank(message) || KsStringUtils.isBlank(privateKey)) {
                throw new KsMerchantApiException("decode param is blank");
            }
            Cipher cipher = Cipher.getInstance(CIPHER_ALGORITHM);
            byte[] key = Base64.decodeBase64(privateKey);
            SecretKeySpec keySpec = new SecretKeySpec(key, KEY_ALGORITHM);
            cipher.init(Cipher.DECRYPT_MODE, keySpec, new IvParameterSpec(new byte[16]));
            return new String(cipher.doFinal(Base64.decodeBase64(message)), CHARSET);
        } catch (Exception e) {
            throw new KsMerchantApiException("decode message fail", e);
        }
    }

已经根据Java demo 写出了一个PHP版。只是拿实际参数怎么运行都是解析false

        
        function decode($message, $privateKey)
        {
            // base64 反编码数据
            $message = base64_decode($message);
            // base64 反编码密钥
            $key = base64_decode($privateKey);
            // Iv向量我根据demo代码猜应该是反编码密钥后的前16位
            $iv = substr($key, 0, 16);
            // 只知道Java的加密是 采用AES加密。我PHP对应 aes-256-cbc? 不知道对不对
            $result = openssl_decrypt($message, 'aes-256-cbc', $key, OPENSSL_RAW_DATA, $iv);
            return $result;
        }

可提供参数密钥,寻求相关大佬指教

补充文档地址: 文档地址

###

已被蒙中加密方式AES-128-CBC 无向量,问题已解决

###

这是AES加解密,给你个解密的你参考下

private function AES_ecb128_decrypt_base64($cipher_text_base64,$key){
        $cipher_text_dec = base64_decode($cipher_text_base64);
        $cipher_text = mcrypt_decrypt(MCRYPT_RIJNDAEL_128,$key,$cipher_text_dec,MCRYPT_MODE_ECB);
        return rtrim($cipher_text,"\0");
    }

或者你搜下相关文章
也可以在线调试AES在线加解密

版权声明:本文转载自网络,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。本站转载出于传播更多优秀技术知识之目的,如有侵权请联系QQ/微信:153890879删除

相关文章
  • 请问下prometheus怎么进行自定义的按业

    请问下prometheus怎么进行自定义的按业

  • 节流函数为什么,点击无效,监听窗口大

    节流函数为什么,点击无效,监听窗口大

  • express访问静态资源失败

    express访问静态资源失败

  • IE 浏览器下 match 方法报错

    IE 浏览器下 match 方法报错

腾讯云代理商
海外云服务器