javascript - 从 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 函数吗?或者是否有任何可用的吊舱/框架?
先感谢您。
解决方案
你可以为 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")
}
推荐阅读
- c++ - Template metaprogram to find similar consecutive typenames
- c# - 如何根据来源过滤 QnAMaker 问题
- asp.net - 有没有办法在数据表的表达式中有 3 个条件?
- git - 用于了解分叉存储库的拉取请求 (PR) 的文件更改的 Git 命令
- r - GGplot boxplot 和 dotplot 并排
- python - QTextEdit 上的样式滚动条(使用自定义图像)
- ssh - VitrtualBox 使用 SSH 密钥连接到 GitLab
- angular - Angular 7 Route 动画在嵌套路由器插座中不起作用
- python - 用户的 Python SQLAlchemy 身份验证失败
- math - 聚类分析 - 多参数