
奇怪的是,如果我创建一个Objective-C类,我可以与API交互没有任何问题,所以这似乎是独特的Swift。
另外如果有人可以告诉我在swift中相当于uint8_t的消息[CC_SHA1_DIGEST_LENGTH]我会非常感谢
你可以在Swift做到这一点。只需确保添加#import< CommonCrypto / CommonHMAC.h>到桥接Objective-C桥接头。enum CryptoAlgorithm { case MD5,SHA1,SHA224,SHA256,SHA384,SHA512 var HMACAlgorithm: CCHmacAlgorithm { var result: Int = 0 switch self { case .MD5: result = kCCHmacAlgMD5 case .SHA1: result = kCCHmacAlgSHA1 case .SHA224: result = kCCHmacAlgSHA224 case .SHA256: result = kCCHmacAlgSHA256 case .SHA384: result = kCCHmacAlgSHA384 case .SHA512: result = kCCHmacAlgSHA512 } return CCHmacAlgorithm(result) } var digestLength: Int { var result: Int32 = 0 switch self { case .MD5: result = CC_MD5_DIGEST_LENGTH case .SHA1: result = CC_SHA1_DIGEST_LENGTH case .SHA224: result = CC_SHA224_DIGEST_LENGTH case .SHA256: result = CC_SHA256_DIGEST_LENGTH case .SHA384: result = CC_SHA384_DIGEST_LENGTH case .SHA512: result = CC_SHA512_DIGEST_LENGTH } return Int(result) }}extension String { func hmac(algorithm: CryptoAlgorithm,key: String) -> String { let str = self.cStringUsingEnCoding(NSUTF8StringEnCoding) let strLen = Int(self.lengthOfBytesUsingEnCoding(NSUTF8StringEnCoding)) let digestLen = algorithm.digestLength let result = UnsafeMu@R_419_5991@Pointer<CUnsignedChar>.alloc(digestLen) let keyStr = key.cStringUsingEnCoding(NSUTF8StringEnCoding) let keyLen = Int(key.lengthOfBytesUsingEnCoding(NSUTF8StringEnCoding)) CCHmac(algorithm.HMACAlgorithm,keyStr!,keyLen,str!,strLen,result) let digest = stringFromresult(result,length: digestLen) result.dealloc(digestLen) return digest } private func stringFromresult(result: UnsafeMu@R_419_5991@Pointer<CUnsignedChar>,length: Int) -> String { var hash = NSMu@R_419_5991@String() for i in 0..<length { hash.appendFormat("%02x",result[i]) } return String(hash) }} 总结 以上是内存溢出为你收集整理的osx – Swift中的CommonHMAC全部内容,希望文章能够帮你解决osx – Swift中的CommonHMAC所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)