MD5加密算法多用于文件的驗(yàn)證, 比如說登錄密碼的匹配就是利用MD5的加密方式,還比如說安卓手機(jī)刷ROM包, windows封裝系統(tǒng)等為了防止他人對文件進(jìn)行篡改,都有使用MD5加密對其驗(yàn)證.
MD5簡介
1藕漱、簡單說明:
全稱是:Message Digest Algorithm 5肃拜,譯為“消息摘要算法第5版”
效果:對輸入信息生成唯一的128位散列值(32個(gè)字符)
MD5生成的是固定的128bit推励,即128個(gè)0和1的二進(jìn)制位雁刷,而在實(shí)際應(yīng)用開發(fā)中垛玻,通常是以16進(jìn)制輸出的,所以正好就是32位的16進(jìn)制贩耐,說白了也就是32個(gè)16進(jìn)制的數(shù)字蚓土。
2、MD5的特點(diǎn):
(1)輸入兩個(gè)不同的明文不會得到相同的輸出值
(2)根據(jù)輸出值桥帆,不能得到原始的明文医增,即其過程不可逆(只能加密, 不能解密)
3、 MD5的應(yīng)用:
由于MD5加密算法具有較好的安全性环葵,而且免費(fèi)调窍,因此該加密算法被廣泛使用
大多數(shù)的登錄功能向后臺提交密碼時(shí)都會使用到這種算法
4宝冕、注意點(diǎn):
(1)一定要和后臺開發(fā)人員約定好张遭,MD5加密的位數(shù)是16位還是32位(大多數(shù)都是32位的),16位的可以通過32位的轉(zhuǎn)換得到地梨。
(2)MD5加密區(qū)分 大小寫菊卷,使用時(shí)要和后臺約定好。
5宝剖、MD5解密:
解密網(wǎng)站: http://www.cmd5.com/
MD5代碼:
自定義一個(gè)繼承自NSObject的類:MD5Tool類
MD5Tool.h
#import <Foundation/Foundation.h>
@interface MD5Tool : NSObject
/**
* MD5加密, 32位 小寫
*
* @param str 傳入要加密的字符串
*
* @return 返回加密后的字符串
*/
+(NSString *)MD5ForLower32Bate:(NSString *)str;
/**
* MD5加密, 32位 大寫
*
* @param str 傳入要加密的字符串
*
* @return 返回加密后的字符串
*/
+(NSString *)MD5ForUpper32Bate:(NSString *)str;
/**
* MD5加密, 16位 小寫
*
* @param str 傳入要加密的字符串
*
* @return 返回加密后的字符串
*/
+(NSString *)MD5ForLower16Bate:(NSString *)str;
/**
* MD5加密, 16位 大寫
*
* @param str 傳入要加密的字符串
*
* @return 返回加密后的字符串
*/
+(NSString *)MD5ForUpper16Bate:(NSString *)str;
@end
MD5Tool.m
#import "MD5Tool.h"
#import <CommonCrypto/CommonCrypto.h>
@implementation MD5Tool
#pragma mark - 32位 小寫
+(NSString *)MD5ForLower32Bate:(NSString *)str{
//要進(jìn)行UTF8的轉(zhuǎn)碼
//1.首先將字符串轉(zhuǎn)換成UTF-8編碼, 因?yàn)镸D5加密是基于C語言的,所以要先把字符串轉(zhuǎn)化成C語言的字符串
const char* input = [str UTF8String];
//2.然后創(chuàng)建一個(gè)字符串?dāng)?shù)組,接收MD5的值
unsigned char result[CC_MD5_DIGEST_LENGTH];
//3.計(jì)算MD5的值, 這是官方封裝好的加密方法:把我們輸入的字符串轉(zhuǎn)換成16進(jìn)制的32位數(shù),然后存儲到result中
CC_MD5(input, (CC_LONG)strlen(input), result);
/**
第一個(gè)參數(shù): 要加密的字符串
第二個(gè)參數(shù): 獲取要加密字符串的長度
第三個(gè)參數(shù): 接收結(jié)果的數(shù)組
*/
//4.創(chuàng)建一個(gè)字符串保存加密結(jié)果
NSMutableString *digest = [NSMutableString stringWithCapacity:CC_MD5_DIGEST_LENGTH * 2];
//5.從result 數(shù)組中獲取加密結(jié)果并放到 saveResult -> (digest) 中
for (NSInteger i = 0; i < CC_MD5_DIGEST_LENGTH; i++) {
[digest appendFormat:@"%02x", result[i]];
}
/*
x表示十六進(jìn)制洁闰,%02X 意思是不足兩位將用0補(bǔ)齊,如果多余兩位則不影響
NSLog("%02X", 0x888); //888
NSLog("%02X", 0x4); //04
*/
return digest;
}
#pragma mark - 32位 大寫
+(NSString *)MD5ForUpper32Bate:(NSString *)str{
//要進(jìn)行UTF8的轉(zhuǎn)碼
const char* input = [str UTF8String];
unsigned char result[CC_MD5_DIGEST_LENGTH];
CC_MD5(input, (CC_LONG)strlen(input), result);
NSMutableString *digest = [NSMutableString stringWithCapacity:CC_MD5_DIGEST_LENGTH * 2];
for (NSInteger i = 0; i < CC_MD5_DIGEST_LENGTH; i++) {
[digest appendFormat:@"%02X", result[i]];
}
return digest;
}
#pragma mark - 16位 大寫
+(NSString *)MD5ForUpper16Bate:(NSString *)str{
NSString *md5Str = [self MD5ForUpper32Bate:str];
NSString *string;
for (int i=0; i<24; i++) {
string=[md5Str substringWithRange:NSMakeRange(8, 16)];
}
return string;
}
#pragma mark - 16位 小寫
+(NSString *)MD5ForLower16Bate:(NSString *)str{
NSString *md5Str = [self MD5ForLower32Bate:str];
NSString *string;
for (int i=0; i<24; i++) {
string=[md5Str substringWithRange:NSMakeRange(8, 16)];
}
return string;
}
@end
使用:
導(dǎo)入MD5Tool.h
調(diào)用類方法:
NSString *str1 = [MD5Tool MD5ForLower16Bate:@"MD5加密算法"];
NSLog(@"小寫16位:%@", str1);
NSString *str2 = [MD5Tool MD5ForLower32Bate:@"MD5加密算法"];
NSLog(@"小寫32位:%@", str2);
NSString *str3 = [MD5Tool MD5ForUpper16Bate:@"MD5加密算法"];
NSLog(@"大寫16位:%@", str3);
NSString *str4 = [MD5Tool MD5ForUpper32Bate:@"MD5加密算法"];
NSLog(@"大寫32位:%@", str4);
加密的結(jié)果如下
2016-12-05 22:05:42.224 new[1258:58874] 小寫16位:02dc4b81cf28f276
2016-12-05 22:05:42.715 new[1258:58874] 小寫32位:89a216fa02dc4b81cf28f276d3e8493b
2016-12-05 22:05:43.217 new[1258:58874] 大寫16位:02DC4B81CF28F276
2016-12-05 22:05:43.754 new[1258:58874] 大寫32位:89A216FA02DC4B81CF28F276D3E8493B