我基本上试图采取一个字符串,并在
PHP中做这样的事情:
$signature= base64_encode(hash_hmac('sha1', $data, $secretKey, true));
但是,在Swift中这样做……
我看到很多关于其他人试图使用CommonCrypto做事的帖子,但该模块似乎没有安装.
真的有3个问题:
> CommonCrypto是正确的方法吗?
>如果是这样,我该如何添加框架?
>如果CommonCrypto不是最好的方法,那是什么?
我当前的代码如下所示:
var authString:String = "PUT\nTEST=BLAH\nTEST2=BLAHBLAHBLAH"
let hmacResult:String = authString.sha1()
...
extension String {
func sha1() -> String {
//Do Something...
}
}
最佳答案 你绝对应该使用CommonCrypto,因为它已经在每台设备上都可用,经过充分测试和快速.您只需要添加一个包含的桥接头
#import <CommonCrypto/CommonCrypto.h>
如前所述,您可以查找here如何添加桥接头.
要计算HMAC,您只需要此扩展名:
extension String {
func hmac(key: String) -> String {
var digest = [UInt8](repeating: 0, count: Int(CC_SHA1_DIGEST_LENGTH))
CCHmac(CCHmacAlgorithm(kCCHmacAlgSHA1), 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")
结果:
0c94515c15e5095b8a87a50ba0df3bf38ed05fe6