md5加密算法多用于文件的验证, 比如说登录密码的匹配就是利用MD5的加密方式,还比如说安卓手机刷ROM包, windows封装系统等为了防止他人对文件进行篡改,都有使用MD5加密对其验证.
SHA1用的不多,这里也做个使用笔记。
下面介绍一下MD5加密实现方法:因为我们是要给字符串进行MD5加密,所以我们可以使用Catagory给Nsstring类扩展一个 MD5加密的功能
首先创建一个Catagory类
在.h里面建立一个方法
@interface NSString (MD5)- (NSString *)stringToMD5:(NSString *)str;-(NSString*) sha1:(NSString *)str;@end在.m里实现方法
#import "NSString+MD5.h"#import <CommonCrypto/CommonCrypto.h>/*记得要导入这个框架和它的头文件*/@implementation NSString (MD5)- (NSString *)stringToMD5:(NSString *)str{//1.首先将字符串转换成UTF-8编码, 因为MD5加密是基于C语言的,所以要先把字符串转化成C语言的字符串 const char *fooData = [str UTF8String];//2.然后创建一个字符串数组,接收MD5的值 unsigned char result[CC_MD5_DIGEST_LENGTH];//3.计算MD5的值, 这是官方封装好的加密方法:把我们输入的字符串转换成16进制的32位数,然后存储到result中 CC_MD5(fooData, (CC_LONG)strlen(fooData), result);// CC_MD5(fooData, (unsigned int)strlen(fooData), result); /** 第一个参数:要加密的字符串 第二个参数: 获取要加密字符串的长度 第三个参数: 接收结果的数组 *///4.创建一个字符串保存加密结果 NSMutableString *saveResult = [NSMutableString string];// NSMutableString *saveResult = [NSMutableString stringWithCapacity:CC_MD5_DIGEST_LENGTH * 2];//5.从result 数组中获取加密结果并放到 saveResult中 for (int i = 0; i < CC_MD5_DIGEST_LENGTH; i++) { [saveResult appendFormat:@"%02x", result[i]]; } /* x表示十六进制,%02X 意思是不足两位将用0补齐,如果多余两位则不影响 NSLog("%02X", 0x888); //888 NSLog("%02X", 0x4); //04 x大写或小写,输出也会相应转成大写或小写 */ return saveResult;}//sha1 encode-(NSString*) sha1:(NSString *)str{ const char *cstr = [str cStringUsingEncoding:NSUTF8StringEncoding]; NSData *data = [NSData dataWithBytes:cstr length:str.length]; uint8_t digest[CC_SHA1_DIGEST_LENGTH]; CC_SHA1(data.bytes, (unsigned int)data.length, digest); NSMutableString* output = [NSMutableString stringWithCapacity:CC_SHA1_DIGEST_LENGTH * 2]; for(int i = 0; i < CC_SHA1_DIGEST_LENGTH; i++) [output appendFormat:@"%02x", digest[i]]; return output;}
新闻热点
疑难解答