
我已经转换了大部分内容,但我无法从数据中获取字节数:
import Foundationimport CommonCryptostruct 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.
总结以上是内存溢出为你收集整理的Swift 3中的数据MD5全部内容,希望文章能够帮你解决Swift 3中的数据MD5所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)