Java与PHP环境下DES加密解密互通,需要精确匹配密钥和编码方式,才能保证数据安全完整。本文将详细讲解如何实现Java DES加密字符串在PHP环境下的正确解密。
Java端采用secureutil.des(“加解密key”.getBytes())方法进行DES加密,未启用初始向量(IV),即DES-ECB模式。此模式简洁但安全性较低,因为相同明文加密结果相同。
Java加密流程:使用密钥“加解密key”初始化DES加密对象,调用des.encryptHex(“待加密内容”)方法加密字符串,返回十六进制密文。然而,原始Java代码片段不完整,缺少将加密结果转换为PHP可处理格式的关键步骤。PHP的openssl_decrypt函数通常需要Base64编码的密文。因此,Java端需将加密后的字节数组Base64编码。
完整的Java加密示例,包含Base64编码:
立即学习“PHP免费学习笔记(深入)”;
final String key = "sg202303"; final String value = "> 本文参与了[segmentfault 思否面试闯关挑战赛],欢迎正在阅读的你也加入。"; final byte[] encrypt = SecureUtil.des(key.getBytes(StandardCharsets.UTF_8)).encrypt(value); final String encode = Base64.getEncoder().encodeToString(encrypt); System.out.println(encode);
此代码使用Base64.getEncoder().encodeToString方法将加密字节数组转换为Base64编码字符串,输出为Base64编码密文。
对应的PHP解密代码:
$xxx = 'P+fEE0NngTu8Ak1E78zGGds3ozPA+M6h1u8v/FMih/Wi1k3YM/q+In+3wUgTv1XGhViBxCRYpqofV5ih0BN+vZTf2fnT4VbH59eRTAQoyl+4ePrKtVf1FngTbcBAT3CHNaYVUIXMbsAUpLwpcgMhJlqM6k4qbzqnEndrIMCzkkyk413alLIUy2/Fo97PvGdR'; $method = 'DES-ECB'; $key = 'sg202303'; var_dump(openssl_decrypt(base64_decode($xxx), $method, $key));
此PHP代码使用openssl_decrypt函数,指定DES-ECB模式和密钥“sg202303”,对Base64解码后的密文进行解密,输出解密结果。 请注意:openssl_decrypt函数需要Base64编码的密文。Java端需Base64编码,PHP端需Base64解码(代码中虽然未显式解码,但openssl_decrypt会自动处理Base64编码字符串)。 Java端未进行Base64编码,PHP解密将失败。 密钥必须与Java端加密密钥完全一致。