我正在尝试获取我的数据的MD5哈希值(从interweb下载的图像).不幸的是,我已经将框架升级到
swift 3,而我一直使用的方法现在不起作用.
我已经转换了大部分内容,但我无法从数据中获取字节数:
import Foundation import CommonCrypto struct MD5 { static func get(data: Data) -> String { var digest = [UInt8](repeating: 0,count: Int(CC_MD5_DIGEST_LENGTH)) CC_MD5(data.bytes,CC_LONG(data.count),&digest) var digestHex = "" for index in 0..<Int(CC_MD5_DIGEST_LENGTH) { digestHex += String(format: "%02x",digest[index]) } return digestHex } }
CommonCrypto已作为自定义模块导入.问题是我得到’字节’不可用:在CC_MD5上使用withUnsafeBytes(data.bytes,…
所以问题是,如何从数据中获取字节并且此解决方案是否有效?
CC_MD5(data.bytes,&digest)
如上所述,字节不可用,因为它很危险.它是进入内存的原始指针而不是消失.推荐的解决方案是使用withUnsafeBytes,它承诺目标在指针范围内不会消失.从内存来看,它看起来像这样:
data.withUnsafeBytes { bytes in CC_MD5(bytes,&digest) }
关键是字节指针不能转移到数据不再有效的范围内.
有关CCHmac的示例(与MD5非常相似),请参阅RNCryptor.