什么是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](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
~~~
- 前言
- iOS開發實踐之SQLite3
- iOS開發實踐之FMDB
- Obj-C與javascript交互之WebViewJavascriptBridge
- iOS開發實踐之UIWebView
- iOS開發實踐之多線程(基本概念)
- iOS開發實踐之多線程(NSThread)
- iOS開發實踐之多線程(GCD)
- iOS開發實踐之多線程(單例模式)
- iOS開發實踐之xib加載注意問題
- iOS開發實踐之多線程(NSOperation)
- iOS開發實踐之cell下載圖片(NSOperation)
- iOS開發實踐之cell下載圖片(自定義NSOperation)
- iOS開發實踐之cell下載圖片(SDWebImage)
- iOS開發實踐之JSON
- iOS開發實踐之XML
- iOS開發實踐之GET和POST請求
- iOS開發實踐之網絡檢測Reachability
- iOS開發實踐之MD5加密