Я создаю реактивное приложение, в котором мне нужно зашифровать с TripleDES, используя режим ECB и заполнение Pkcs7.
У меня есть код Android Java, который выполняет алгоритм шифрования, который я хочу скопировать.
В реакции на нативность я добавил CryptoJS из https://github.com/brix/crypto-js и вызвал метод CryptoJS.enc.TripleDES.encrypt (), но он возвращает результат, отличный от ожидаемого.
Это код Android, который я хочу набрать:
private static byte[] encrypt(String message, String privateKeyMobile) throws Exception {
final MessageDigest md = MessageDigest.getInstance("MD5");
final byte[] digestOfPassword = md.digest(privateKeyMobile.getBytes("utf-8"));
final byte[] keyBytes = new byte[24];
int q;
for (q = 0; q < 24 && q < digestOfPassword.length; q++) {
keyBytes[q] = digestOfPassword[q];
}
if (q < 24) {
for (int u = q; u < 24; u++)
keyBytes[u] = 0;
}
for (int j = 0, k = 16; j < 8;) {
keyBytes[k++] = keyBytes[j++];
}
final SecretKey key = new SecretKeySpec(keyBytes, "DESede");
final Cipher cipher = Cipher.getInstance("DESede/ECB/PKCS7Padding");
cipher.init(Cipher.ENCRYPT_MODE, key);
final byte[] plainTextBytes = message.getBytes("utf-8");
return cipher.doFinal(plainTextBytes);
}
Это мой реактивный код:
encrypt(message, key) {
let md5key = CryptoJS.enc.MD5(key);
var ciphertext = TripleDES.encrypt(message, md5key, {
mode: CryptoJS.mode.ECB,
padding: CryptoJS.pad.Pkcs7
});
return ciphertext;
}
Обе функции возвращают разные выходы.
Этот php-код работает так же, как и Java-код:
https://webtools.workontech.com/triple-des-encryption-online
Другие онлайн-инструменты TripleDES возвращают тот же самый результат реакции.