标签:
什么是MD5:
全称是Message Digest Algorithm 5,译为“消息摘要算法第5版”
效果:对输入信息生成唯一的128位散列值(32个字符)
MD5的特点:
输入两个不同的明文不会得到相同的输出值
根据输出值,不能得到原始的明文,即其过程不可逆
MD5的应用:
由于MD5加密算法具有较好的安全性,而且免费,因此该加密算法被广泛使用
主要运用在数字签名、文件完整性验证以及口令加密等方面
MD5改进:
加盐(Salt):在明文的固定位置插入随机串,然后再进行MD5
先加密,后乱序:先对明文进行MD5,然后对加密得到的MD5串的字符进行乱序
栗子:
导入NSString+hash.h封装好的加密分类算法:下载地址http://pan.baidu.com/s/1o7hA4Vw
ViewController.m
// ViewController.m #import "ViewController.h" #import "NSString+Hash.h" @interface ViewController () @end @implementation ViewController - (void)viewDidLoad { [super viewDidLoad]; [self MD5]; [self MD5Salt:@"san"]; [self doubleMD5]; [self MD5Reorder]; } //MD5加密 -(void)MD5{ NSString *pwd = @"123456"; NSString *pwdMD5 = [pwd md5String]; NSLog(@"%@",pwdMD5); } /** * 撒盐 加密 MD5($pass.$salt) */ -(void)MD5Salt:(NSString *)salt{ NSString *pwd = @"123456"; pwd =[pwd stringByAppendingString:salt]; //撒盐:随机地往明文中插入任意字符串 NSString *pwdMD5 = [pwd md5String]; NSLog(@"%@",pwdMD5); } /** * MD5(MD5($pass)) */ - (void)doubleMD5{ NSString *pwd = @"123456"; NSString *pwdMD5MD5 = [[pwd md5String]md5String]; NSLog(@"%@",pwdMD5MD5); } /** * 先加密,后乱序 */ - (void)MD5Reorder{ NSString *pwd = @"123456"; NSString *pwdMD5 = [pwd md5String]; NSLog(@"oldpwdMD5=%@",pwdMD5); NSString *prefix = [pwdMD5 substringFromIndex:3]; //从下标为3的开始截取(包含3) NSString *subfix = [pwdMD5 substringToIndex:3]; //截取0到3的字符串(不包含3) pwdMD5 = [prefix stringByAppendingString:subfix]; NSLog(@"newpwdMD5=%@",pwdMD5); } @end
标签:
原文地址:http://blog.csdn.net/zhixinhuacom/article/details/50616493