加密/解密Java和PHP之间的字符串

时间:2012-01-06 11:24:55

标签: java php android encryption aes

我正在使用AES加密来加密和解密服务器端的php和Android应用程序(作为客户端)之间的字符串。

PHP中的加密字符串是:

HaxRKnMxT24kCJWUXaVvqDHahzurJQK+sYA4lIHql/U=

在Java中是:

HaxRKnMxT24kCJWUXaVvqD/KMEkJTPTXEcCsHIYGX9TGtCNOHQcJyUURPk8qlgf3

我正在PHP脚本中使用phpseclib来进行加密。

我在这里缺少什么?

此处的相关Java代码

SecretKeySpec skeySpec = new SecretKeySpec(pad16(pass), "AES");
Cipher c = Cipher.getInstance("AES");
c.init(Cipher.ENCRYPT_MODE, skeySpec);
byte[] out = c.doFinal( input )

这里的PHP代码:

$aes = new Crypt_AES();
$aes->setKey('password');
$encrypted_encoded_text =  base64_encode($aes->encrypt($plaintext));

1 个答案:

答案 0 :(得分:4)

为了使加密/解密能够在不同的语言中工作,很少有东西需要相同。

  1. 加密算法(呃!)
  2. Key(呃,再次!)
  3. 密钥大小
  4. 运作模式(ECB,CBC,CTR)
  5. 初始化向量(如果是CBC,不需要ECB)
  6. 填充方案

    也可能还有其他一些因素....

  7. 你确定这两种语言都是一样的吗?如果是,那么你的加密/解密应该完美无缺,除非实现中存在错误(这种情况非常罕见但可能)。