什么是


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



版权声明:本文为zhixinhuacom原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
原文链接:https://blog.csdn.net/zhixinhuacom/article/details/50616493