概念解释:Message Digest(摘要) Algorithm (算法) : 信息摘要算法第五版
就是把任意长度的字节串编程一个一定长的十六进制数字串
特点
1、压缩性:任意长度的数据,算出的MD5值长度都是固定的。
2、容易计算:从原数据计算出MD5值很容易。
3、抗修改性:对原数据进行任何改动,哪怕只修改1个字节,所得到的MD5值都有很大区别。
4、强抗碰撞:已知原数据和其MD5值,想找到一个具有相同MD5值的数据(即伪造数据)是非常困难的。
算法的输出由四个32位分组组成,将这四个32位分组级联后将生成一个128位散列值,最终返回一个128位的1或者0
这个算法是不可逆的。
这个算法可以帮你查看文件是否被修改
struct MD5Utility {
static func getMD5FromString(string: String) -> NSMutableString {
let original = string.cStringUsingEncoding(NSUTF8StringEncoding)
let digest = UnsafeMutablePointer<UInt8>.alloc(16)
let length = UInt32(strlen(original!))
CC_MD5(original!, length, digest)
return getMD5Str(digest)
}
static func getMD5FromData(data: NSData) ->NSMutableString {
let original = data.bytes
let ori = unsafeBitCast(original, UnsafePointer<Int8>.self)
let MD5Length = Int(CC_MD5_DIGEST_LENGTH)
let digest = UnsafeMutablePointer<UInt8>.alloc(MD5Length)
let length = UInt32(strlen(ori))
CC_MD5(original, length, digest)
return getMD5Str(digest)
}
static func getMD5FromFilePath(path: String) -> NSMutableString {
let handel = NSFileHandle(forReadingAtPath: path)
if handel == nil {
print("failed")
return NSMutableString(string: "file is not opened")
}
// 先声明一个context上下文
var context = CC_MD5_CTX()
// 初始化一个上下文
CC_MD5_Init(&context)
var done = true
while done {
var data = handel?.readDataOfLength(1024)
// 对上下文进行更新
CC_MD5_Update(&context, &data, UInt32((data?.length)!))
if data?.length == 0 {
done = false
}
}
let digest = UnsafeMutablePointer<UInt8>.alloc(16)
// 最终确定上下文
CC_MD5_Final(digest, &context)
return getMD5Str(digest)
}
private static func getMD5Str(digest: UnsafeMutablePointer<UInt8>) -> NSMutableString {
let md5String = NSMutableString(capacity: 16 * 2)
for index in 0..<16 {
md5String.appendFormat("%02x", digest[index])
}
digest.destroy()
return md5String
}
}
原文:http://www.cnblogs.com/kuaixian/p/5557280.html