如何使用 AES 算法使用 phpseclib 加密并使用 java 解密

How to encrypt with phpseclib and decrypt with java using AES algorithm

我必须使用 AES 算法对服务器 运行 php 上的数据进行加密,然后将它们发送到另一台服务器 运行 Java。我选择分别为 php 和 Java 端使用 phpseclib 和 javax.crypto 包。 不幸的是有填充异常。这是我的代码:

php 侧:

$aes = new Crypt_AES('MODE_ECB');
$key = "secretkeyfor1234secretke";
$aes->setKey($key);
$plaintext = 'Good evening this is just a test';
$cryptedmessage =  base64_encode($aes->encrypt($plaintext));

java 方面: clefAES 包含密钥,数据包含密文。我使用 RSA 加密发送密钥(此处未报告)。

data = EFjTatx2VkAZR3ScS0UadQr8M6zEkIz/kAX0Cl+XH2FNNHVbeJsEd2b+zWlEkvR6;//( it is base64 encoded )
Cipher aescipher = Cipher.getInstance("AES/ECB/NoPadding", "SunJCE");
Key keySpec = new SecretKeySpec(clefAES, "AES");                   
byte[] encryptedTextByte = decoder.decodeBuffer(data);
aescipher.init(Cipher.DECRYPT_MODE, keySpec);
byte[] decryptedByte = aescipher.doFinal(encryptedTextByte);
String decryptedText = new String(decryptedByte);

这是 decryptedText 给出的结果:

晚上好,thicx#3mg? i��#������O��q

如果有人知道我为什么会得到这个结果以及如何解决这个问题,那将非常有帮助。 phpseclib 是否与用于 aes 加密的 javax.crypto 包兼容?这是实现我想要实现的目标的最佳方式吗?

这是我从您的 PHP 代码中得到的输出:

GYQGpH6fRpHBP0ACElbcp1nvcS0ojcqzvnqclHxvB+BtgM4KEH+K7Q2F6rhEx0hM

这与您传递给 Java 代码的内容形成对比。

此外,您的 PHP 代码未执行 ECB 模式。它正在执行 CBC 模式。这是因为 new Crypt_AES('MODE_ECB'); 不是您需要使用的代码。相反,这是执行 ECB 模式需要使用的代码:

new Crypt_AES(CRYPT_MODE_ECB);

此外,phpseclib 默认进行填充。要禁用它,您需要这样做:

$aes->disablePadding();

说了这么多之后,我得到了这个作为输出:

GYQGpH6fRpHBP0ACElbcp9i8pjKf4G7wiPLDL7TM1Ec=