Я работаю над шифрованием AES в iOS Swift и бэкэнд, где используется JavaScript. Это не дешифровать в бэкэнде то, что я зашифровал во внешнем интерфейсе
Вот код бэкенда
var keySize = 256;
var ivSize = 128;
var iterations = 10
var message = "Hello World1";
var password = "E4F1E897-A39A-4A27-ADC9-ABD96CCAAB22";
function encrypt (msg, pass) {
var salt = CryptoJS.lib.WordArray.random(128/8);
// var salt = "456b88dbdde11a325c54838952e48da6"
var key = CryptoJS.PBKDF2(pass, salt, {
keySize: keySize/32,
iterations: iterations
});
var iv = CryptoJS.lib.WordArray.random(128/8);
// var iv = "bjh6fr6yiugc6754bgfhy8i"
var encrypted = CryptoJS.AES.encrypt(msg, key, {
iv: iv,
padding: CryptoJS.pad.Pkcs7,
mode: CryptoJS.mode.CBC });
// salt, iv will be hex 32 in length
// append them to the ciphertext for use in decryption
var transitmessage = salt.toString()+ iv.toString() + encrypted.toString();
return transitmessage; }
function decrypt (transitmessage, pass) {
var salt = CryptoJS.enc.Hex.parse(transitmessage.substr(0, 32));
var iv = CryptoJS.enc.Hex.parse(transitmessage.substr(32, 32))
var encrypted = transitmessage.substring(64);
var key = CryptoJS.PBKDF2(pass, salt, {
keySize: keySize/32,
iterations: iterations });
var decrypted = CryptoJS.AES.decrypt(encrypted, key, {
iv: iv,
padding: CryptoJS.pad.Pkcs7,
mode: CryptoJS.mode.CBC })
return decrypted; }
var encrypted = encrypt(message, password);
var decrypted = decrypt(encrypted, password);
$('#encrypted').text("Encrypted: "+encrypted);
$('#decrypted').text("Decrypted: "+ decrypted.toString(CryptoJS.enc.Utf8) );
В Swift я использую CryptoSwift как
let sal = AES.randomIV(128/8)
let ivv = AES.randomIV(128/8)
let password: Array<UInt8> = Array("E4F1E897-A39A-4A27-ADC9-ABD96CCAAB22".utf8)
let mkey = try! PKCS5.PBKDF2(password: password, salt: sal, iterations: 10,keyLength: 32, variant: .sha256).calculate()
let input: Array<UInt8> = Array("Siva Kumar".utf8)
do { let encrypted = try AES(key: mkey, blockMode: CBC(iv: ivv), padding: .pkcs7).encrypt(input)
let decrypted = try AES(key: mkey, blockMode: CBC(iv: ivv), padding: .pkcs7).decrypt(encrypted)
let cscs = sal.toHexString() + ivv.toHexString() + String(encrypted.toHexString())
print(cscs) } catch { print(error) }
Зашифрованный один не расшифровывать в Backend. Пожалуйста, помогите мне в этом Спасибо заранее