我正在尝试获取我的数据的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.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。