-1
一部のデータを暗号化して、PBEWITHSHAAND3-KEYTRIPLEDES-CBCでサードパーティのサービスに送信する必要があります。phpseclibを使用したPBEWITHSHAAND3-KEYTRIPLEDES-CBCによる暗号化
私は第三者によって提供されるこの実施例のJavaコードを、持っている:
String algorithm = "PBEWITHSHAAND3-KEYTRIPLEDES-CBC";
String password = "eKhfdPKO54OddrfgghuBGHsA5BGTYHon";
byte[] salt = {-87, -101, -56, 50, 86, 52, -29, 3};
int iterations = 19;
String text = "foobar";
Provider bouncy = new org.bouncycastle.jce.provider.BouncyCastleProvider();
Security.addProvider(bouncy);
KeySpec keySpec = new PBEKeySpec(password.toCharArray(), salt, iterations);
SecretKey key = SecretKeyFactory.getInstance(algorithm, bouncy).generateSecret(keySpec);
Cipher cipher = Cipher.getInstance(algorithm, bouncy);
cipher.init(1, key, new PBEParameterSpec(salt, iterations));
System.out.println(new String(Base64.getEncoder().encode(cipher.doFinal(text.getBytes("UTF8")))));
// Output: kaxAiR1Qb9s=
これはphpseclib
を使用して、私の(動作しない)PHPコードです:
$hash = 'sha1';
$kdf = 'pkcs12';
$password = 'eKhfdPKO54OddrfgghuBGHsA5BGTYHon';
$salt = chr(-87) . chr(-101) . chr(-56) . chr(50) . chr(86) . chr(52) . chr(-29) . chr(3);
$iterations = 19;
$text = "foobar";
$cipher = new \phpseclib\Crypt\TripleDES('cbc');
$cipher->setPassword($password, $kdf, $hash, $salt, $iterations);
echo base64_encode($cipher->encrypt($text));
// Output: daAlVF+JjNg=
質問: PHPコードをJavaと同じ出力にするにはどうすればよいですか?
なぜJavaをPHPに変換できるのでしょうか? – Zorkind
あなたのコードには多くの誤りがあります: - \ – Zorkind
私はPHPをjavaに翻訳しようとしていません。私はPHPのものを暗号化しようとしています。 Javaコードは第三者によって提供されました。どちらのコードも機能しており、輸入品を紛失してしまいます。 – txigreman