個(gè)人博客: LiCheng的博客
引言
在開(kāi)發(fā)應(yīng)用的時(shí)候,數(shù)據(jù)的安全性至關(guān)重要,而僅僅用POST請(qǐng)求提交用戶的隱私數(shù)據(jù)帘瞭,還是不能完全解決安全問(wèn)題。因此:提交用戶的隱私數(shù)據(jù)時(shí)蒿讥,一定不要明文提交蝶念,要加密處理后再提交抛腕。
常見(jiàn)的加密算法
MD5 \ SHA \ DES \ 3DES \ RC2和RC4 \ RSA \ IDEA \ DSA \ AES
加密算法的選擇
一般公司都會(huì)有一套自己的加密方案,按照公司接口文檔的規(guī)定去加密媒殉。
MD5簡(jiǎn)介
簡(jiǎn)單說(shuō)明:
MD5:全稱是Message Digest Algorithm 5担敌,譯為“消息摘要算法第5版”
效果:對(duì)輸入信息生成唯一的128位散列值(32個(gè)字符)
MD5生成的是固定的128bit,即128個(gè)0和1的二進(jìn)制位廷蓉,而在實(shí)際應(yīng)用開(kāi)發(fā)中全封,通常是以16進(jìn)制輸出的,所以正好就是32位的16進(jìn)制桃犬,說(shuō)白了也就是32個(gè)16進(jìn)制的數(shù)字刹悴。MD5的特點(diǎn):
(1)輸入兩個(gè)不同的明文不會(huì)得到相同的輸出值
(2)根據(jù)輸出值,不能得到原始的明文攒暇,即其過(guò)程不可逆(只能加密, 不能解密)MD5的應(yīng)用:
由于MD5加密算法具有較好的安全性土匀,而且免費(fèi),因此該加密算法被廣泛使用
大多數(shù)的登錄功能向后臺(tái)提交密碼時(shí)都會(huì)使用到這種算法注意點(diǎn):
(1)一定要和后臺(tái)開(kāi)發(fā)人員約定好形用,MD5加密的位數(shù)是16位還是32位(大多數(shù)都是32位的)就轧,16位的可以通過(guò)32位的轉(zhuǎn)換得到。
(2)MD5加密區(qū)分 大小寫田度,使用時(shí)要和后臺(tái)約定好妒御。MD5解密:
解密網(wǎng)站: http://www.cmd5.com/
MD5代碼:
自定義一個(gè)繼承自NSObject的類:LCMD5Tool類
LCMD5Tool.h文件:
#import <Foundation/Foundation.h>
@interface LCMD5Tool : 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
LCMD5Tool.m文件:
#import "LCMD5Tool.h"
#import <CommonCrypto/CommonCrypto.h>
@implementation LCMD5Tool
#pragma mark - 32位 小寫
+(NSString *)MD5ForLower32Bate:(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 - 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:@"123456"];
NSLog(@"小寫16位:%@", str1);
NSString *str2 = [MD5Tool MD5ForLower32Bate:@"123456"];
NSLog(@"小寫16位:%@", str2);
NSString *str3 = [MD5Tool MD5ForUpper16Bate:@"123456"];
NSLog(@"大寫16位:%@", str3);
NSString *str4 = [MD5Tool MD5ForUpper32Bate:@"123456"];
NSLog(@"大寫32位:%@", str4);
好了, MD5加密就這么搞定了, 可以通過(guò)上面的解密網(wǎng)站測(cè)試自己的加密是否正確!U蚪取乎莉!
<br />
<br />
GitHub: https://github.com/LiCheng244/LCUtils
個(gè)人博客: http://www.licheng244.com/