一,-(NSString *)md5:(NSString *)str { const char *cStr = [str UTF8String];//转换成utf-8 unsigned char result[16];//开辟一个16字节(128位:md5加密出来就是128位/bit)的空间(一个字节=8字位=8个二进制数) CC_MD5( cStr, strlen(cStr), result); /* extern unsigned char *CC_MD5(const void *data, CC_LONG len, unsigned char *md)官方封装好的加密方法 把cStr字符串转换成了32位的16进制数列(这个过程不可逆转) 存储到了result这个空间中 */ return [NSString stringWithFormat: @"%02X%02X%02X%02X%02X%02X%02X%02X%02X%02X%02X%02X%02X%02X%02X%02X", result[0], result[1], result[2], result[3], result[4], result[5], result[6], result[7], result[8], result[9], result[10], result[11], result[12], result[13], result[14], result[15] ]; /* x表示十六进制,%02X 意思是不足两位将用0补齐,如果多余两位则不影响 NSLog("%02X", 0x888); //888 NSLog("%02X", 0x4); //04 */ }
二,MD5加密算法多数用于验证,比如说密码匹配用的就是MD5加密后得到的数值。 输出方式用一个for循环来解决更为方便 NSMutableString *Mstr = [NSMutableString stringWithCapacity:CC_MD5_DIGEST_LENGTH]; for (int i=0; i<CC_MD5_DIGEST_LENGTH; i++) { [Mstr appendFormat:@"%02X",result[i]]; } return Mstr; MD5算法 不管是什么语言得到的结果都是一样的。 可能会有人遇到过ios客户端和java服务器端匹配MD5值会有不一样的,我猜测:并不是算 法有问题,可能是某一方求MD5值少了一步,直接这样搞定的 NSMutableString *Mstr = [NSMutableString stringWithCapacity:CC_MD5_DIGEST_LENGTH]; for (int i=0; i<CC_MD5_DIGEST_LENGTH; i++) { [Mstr appendFormat:@"%d",(char)result[i]]; } return Mstr;