本机HMAC SHA512支持Swift 3.1

时间:2017-06-05 01:23:04

标签: swift sha hmac

我尝试在将数据字符串发送到服务器之前对其进行HMAC SHA512加密,因为这是他们的要求。

我已经在网上找到了许多可能的解决方案,但是所有这些解决方案都需要包含一些模块或框架。

当然,swift 3.1不支持HMACSHA512吗?

很抱歉,如果这是一个愚蠢的问题,我对swift相对较新。

如果可用,我如何使用hmac sha512简单地加密某些数据?

感谢。

1 个答案:

答案 0 :(得分:1)

CommonCrypto是在Apple设备上进行加密的本机方式。您不需要任何模块或框架,只需add a bridging header并导入CommonCrypto:

#import <CommonCrypto/CommonCrypto.h>

然后,您可以通过简单的扩展(Swift 4)计算您的HMAC:

extension String {

    func hmac(key: String) -> String {
        var digest = [UInt8](repeating: 0, count: Int(CC_SHA256_DIGEST_LENGTH))
        CCHmac(CCHmacAlgorithm(kCCHmacAlgSHA256), key, key.count, self, self.count, &digest)
        let data = Data(bytes: digest)
        return data.map { String(format: "%02hhx", $0) }.joined()
    }

}

示例:

let result = "test".hmac(key: "test")

结果:

88cd2108b5347d973cf39cdf9053d7dd42704876d8c9a9bd8e2d168259d3ddf7

如果您在非Apple设备上使用Swift,您确实需要使用外部框架进行加密。