Я шифрую некоторые данные в NodeJs, используя метод ниже. Он отлично работает на Nodejs сервер для шифрования и дешифрования.
Вход для шифрования = "SIYdcYSyiWY5XUqYMrfv31sPF8DSojs1ikghMs4R"
1004 * Зашифрованные выход в NodeJS = «IRhqmwhlFUxS1Zg + Qyr2ykSkAA1cQ5gVts7RIZoULCbYMS / DVsdfTyanGAAu4HkuAZv4ynk + VBPZ6vaTH5xTONfuVRlUavF9X // 12v5et5em1ItPYdlOWkYo5IkodpAQvm5Yrm4F5xaRxRU3 + TAZzOQm / 3YQIlz74X + 3V3 / aV / K4qFebSLUMZJM9glPWo4O + ISDf76ztiN2ynLyvsivSU / qUuQEtPVEK "
encryptAES = ((text) => {
// random initialization vector
const iv = crypto.randomBytes(16);
const salt = crypto.randomBytes(64);
var masterKey = crypto.randomBytes(32);
const key = crypto.pbkdf2Sync(masterKey, salt, 2145, 32, 'sha512');
// AES 256 GCM Mode
const cipher = crypto.createCipheriv('aes-256-gcm', key, iv);
const encrypted = Buffer.concat([cipher.update(text, 'utf8'), cipher.final()]);
// extract the auth tag
const tag = cipher.getAuthTag();
// generate output
return Buffer.concat([salt, iv, tag, masterKey, encrypted]).toString('base64');
});
Я пытаюсь расшифровать его по какой-то причине, но по какой-то причине * 1016 терпит неудачу. Я уверен, что я не использую правильный способ расшифровки. Ниже показано, как далеко я попал
public String decrypt(String base64EncryptedData) throws Exception {
byte[] decryptedData = Base64.getDecoder().decode(base64EncryptedData);
byte[] salt = Arrays.copyOfRange(decryptedData, 0, 64);
byte[] iv = Arrays.copyOfRange(decryptedData, 64, 80);
byte[] tag = Arrays.copyOfRange(decryptedData, 80, 96);
String masterKey = new String(Arrays.copyOfRange(decryptedData, 96, 128), "UTF-8");
byte[] text = Arrays.copyOfRange(decryptedData, 128, decryptedData.length); ;
GCMParameterSpec gcmParameterSpec = new GCMParameterSpec(tag.length * 8, iv);
SecretKeyFactory factory = SecretKeyFactory.getInstance("PBKDF2WithHmacSHA512");
KeySpec spec = new PBEKeySpec(masterKey.toCharArray(), salt, 2145, 32*8);
SecretKey tmp = factory.generateSecret(spec);
key = new SecretKeySpec(tmp.getEncoded(), "AES");
dcipher = Cipher.getInstance("AES/GCM/NoPadding");
dcipher.init(Cipher.DECRYPT_MODE, key, gcmParameterSpec);
byte[] utf8 = dcipher.doFinal(text);
return new String(utf8, "UTF8");
}
В Java я получаю исключение
javax.crypto.AEADBadTagException: Tag mismatch!