簡體   English   中英

從 JS 后端到 iOS 應用程序的 AES 解密

[英]AES decryption from JS backend to iOS app

我正在開發 1 個從 API 獲取加密數據的 iOS 應用程序。 我曾嘗試將 JS 代碼轉換為 swift,但一直無法做到。 我被困在解密部分,在稍后階段,我必須再次為 API 請求加密它。 JS代碼如下:

function hexToBase64(str) {
  return btoa(String.fromCharCode.apply(null,
    str.replace(/\r|\n/g, "").replace(/([\da-fA-F]{2}) ?/g, "0x$1 ").replace(/ +$/, "").split(" "))
  );
}


function base64ToHex(str) {
  for (var i = 0, bin = atob(str.replace(/[ \r\n]+$/, "")), hex = []; i < bin.length; ++i) {
    var tmp = bin.charCodeAt(i).toString(16);
    if (tmp.length === 1) tmp = "0" + tmp;
    hex[hex.length] = tmp;
  }
  return hex.join("");
}

export function decryptFuncForNet(transitmessage, pass) {
  var hexResult = base64ToHex(transitmessage)
  var salt = CryptoJS.enc.Hex.parse(hexResult.substr(0, 64));
  var iv = CryptoJS.enc.Hex.parse(hexResult.substr(64, 32));
  var encrypted = hexToBase64(hexResult.substring(96));
  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.toString(CryptoJS.enc.Utf8);
}

有人可以幫我將其轉換為 swift 函數嗎? 或者是否有任何可用的吊艙/框架?

先感謝您。

你可以為 hexResult 嘗試這樣的事情:

        func hexToBase64(_ str: String) -> String {
            let hexdata = str.data(using: .utf8)!
            return hexdata.base64EncodedString()
        }
        
        func base64ToHex(_ str: String) -> String? {
            if let dataHex = Data(base64Encoded: hexResult),
               let decodedHex = String(data: dataHex, encoding: .utf8) {
                return decodedHex
            }
            return nil
        }
        
        // encrypt
        let transitmessage = "BA5E64C0DE"
        print("---> transitmessage: \(transitmessage)")
        let hexResult = hexToBase64(transitmessage)
        print("---> hexResult: \(hexResult)")
        
        // decrypt
        if let decodedHex = base64ToHex(hexResult) {
            print("---> decodedHex: \(decodedHex) \n")
        }

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM