我正在使用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));
答案 0 :(得分:4)
为了使加密/解密能够在不同的语言中工作,很少有东西需要相同。
填充方案
也可能还有其他一些因素....
你确定这两种语言都是一样的吗?如果是,那么你的加密/解密应该完美无缺,除非实现中存在错误(这种情况非常罕见但可能)。