Шифрование шифрования AES JS (Backend) и Swift (Frontend) - PullRequest
0 голосов
/ 17 марта 2020

Я работаю над шифрованием 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. Пожалуйста, помогите мне в этом Спасибо заранее

...