iOS開發實踐之MD5加密
什麼是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