Swift 中的 SHA256 - 导入框架问题

问题描述 投票:0回答:2

我试图在 Swift 中的一个函数中使用 CC_SHA256_DIGEST_LENGTH,它会抛出一个错误,因为它找不到该符号。我已经尝试了所有方法,在桥头中导入 CommonCrypto 并尝试了 .map 解决方案。没有任何效果。

如何在 Swift 中使用 CC_SHA256_DIGEST_LENGTH?所有解决方案似乎都已停止工作。 谢谢!

ios security swift
2个回答
42
投票

将以下行添加到您的桥接头:

#import <CommonCrypto/CommonHMAC.h>

Swift 2.x 示例:

func doSha256(#dataIn:NSData) -> NSData {
    var shaOut: NSMutableData! = NSMutableData(length: Int(CC_SHA256_DIGEST_LENGTH));
    CC_SHA256(dataIn.bytes, CC_LONG(dataIn.length), UnsafeMutablePointer<UInt8>(shaOut.mutableBytes));

    return shaOut;
}

Swift 3.0 示例:

func hashSHA256(data:Data) -> Data? {
    var hashData = Data(count: Int(CC_SHA256_DIGEST_LENGTH))
    _ = hashData.withUnsafeMutableBytes {digestBytes in
        data.withUnsafeBytes {messageBytes in
            CC_SHA256(messageBytes, CC_LONG(data.count), digestBytes)
        }
    }
    return hashData
}

let clearData   = "clearData0123456".data(using:String.Encoding.utf8)!
print("clearData: \(clearData.map { String(format: "%02hhx", $0) }.joined())")

let hash = hashSHA256(data:clearData)
print("hash: \(hash!.map { String(format: "%02hhx", $0) }.joined())")

输出:

清晰数据:

636c6561724461746130313233343536

哈希:
aabc766b6b357564e41f4f912d494bccbfa16924b574abbdba9e3e9da0c8920a

我没有在目标构建阶段中添加任何框架。
您确定桥接头设置正确吗?我通过添加一个 .m 文件来添加我的,让系统自动添加桥接头并更新任何目标设置。

从已停用的文档部分移出的通用哈希方法:

这个函数接受一个散列名称和要散列的数据并返回一个数据:

name: 字符串形式的哈希函数名称
数据:要散列的数据
返回:散列结果作为数据
func hash(name:String, data:Data) -> Data? {
    let algos = ["MD2":    (CC_MD2,    CC_MD2_DIGEST_LENGTH),
                 "MD4":    (CC_MD4,    CC_MD4_DIGEST_LENGTH),
                 "MD5":    (CC_MD5,    CC_MD5_DIGEST_LENGTH),
                 "SHA1":   (CC_SHA1,   CC_SHA1_DIGEST_LENGTH),
                 "SHA224": (CC_SHA224, CC_SHA224_DIGEST_LENGTH),
                 "SHA256": (CC_SHA256, CC_SHA256_DIGEST_LENGTH),
                 "SHA384": (CC_SHA384, CC_SHA384_DIGEST_LENGTH),
                 "SHA512": (CC_SHA512, CC_SHA512_DIGEST_LENGTH)]
    guard let (hashAlgorithm, length) = algos[name]  else { return nil }
    var hashData = Data(count: Int(length))

    _ = hashData.withUnsafeMutableBytes {digestBytes in
        data.withUnsafeBytes {messageBytes in
            hashAlgorithm(messageBytes, CC_LONG(data.count), digestBytes)
        }
    }
    return hashData
}

注意:MD2、MD4、MD5 和 SHA1 不应在新工作中使用,它们不再安全用于消息摘要的使用。


0
投票

以上都不适合我。这是对 swift5 有效的方法:

import CryptoKit
import CommonCrypto

然后:

let hash = SHA256.hash(data: data). 
© www.soinside.com 2019 - 2024. All rights reserved.