微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

从 JS 后端到 iOS 应用程序的 AES 解密

如何解决从 JS 后端到 iOS 应用程序的 AES 解密

我正在开发 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 函数吗? 或者是否有任何可用的 pod/框架?

提前致谢。

解决方法

你可以为 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: str),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")
        }

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?