Prashant Kumar Sharma:
Ich versuche , die zu replizieren Java - Code für AES - Verschlüsselung und Entschlüsselung in Knoten JS .
Java-Code
SecretKeySpec skeySpec;
String key = "a4e1112f45e84f785358bb86ba750f48";
public void encryptString(String key) throws Exception {
try {
skeySpec = new SecretKeySpec(key.getBytes(), "AES");
cipher = Cipher.getInstance("AES");
cipher.init(1, skeySpec);
byte encstr[] = cipher.doFinal(message.getBytes());
String encData = new String(encstr, "UTF-8");
System.out.println(encData);
} catch (NoSuchAlgorithmException nsae) {
throw new Exception("Invalid Java Version");
} catch (NoSuchPaddingException nse) {
throw new Exception("Invalid Key");
}
}
Knoten JS
var encryptKey = function (text) {
var cipher = crypto.createCipher('aes256', 'a4e1112f45e84f785358bb86ba750f48');
var crypted = cipher.update(text,'utf8', 'hex')
crypted += cipher.final('hex');
console.log(crypted);
return crypted;
}
Ich bin nicht in der Lage , den genauen zu bekommen Chiffre-Text in Knoten JS , die ich in bin immer Java .
Prashant Kumar Sharma:
Schließlich , nach Überprüfung der Java - Docs und Knoten JS Crypto Text & Tabellen verwalten das Ergebnis zu erhalten. Wir haben zu verwenden , crypto.createCipheriv()
anstatt crypto.createCipher
mit einem iv. Hier iv sein null
.
Code:
let crypto = require('crypto');
var iv = new Buffer.from(''); //(null) iv
var algorithm = 'aes-256-ecb';
var password = 'a4e1112f45e84f785358bb86ba750f48'; //key password for cryptography
function encrypt(buffer){
var cipher = crypto.createCipheriv(algorithm,new Buffer(password),iv)
var crypted = Buffer.concat([cipher.update(buffer),cipher.final()]);
return crypted;
}
console.log(encrypt(new Buffer('TextToEncrypt')).toString())