IT虾米网

iOS开发实践之MD5加密详解

luoye 2018年06月23日 手机开发 377 0

什么是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




发布评论

分享到:

IT虾米网

微信公众号号:IT虾米 (左侧二维码扫一扫)欢迎添加!

秒杀倒计时/倒计时iOS代码实现详解
你是第一个吃螃蟹的人
发表评论

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。