我尝试在将数据字符串发送到服务器之前对其进行HMAC SHA512
加密,因为这是他们的要求。
我已经在网上找到了许多可能的解决方案,但是所有这些解决方案都需要包含一些模块或框架。
当然,swift 3.1不支持HMAC
和SHA512
吗?
很抱歉,如果这是一个愚蠢的问题,我对swift相对较新。
如果可用,我如何使用hmac sha512
简单地加密某些数据?
感谢。
答案 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,您确实需要使用外部框架进行加密。