個人博客: LiCheng的博客
引言
在開發應用的時候,數據的安全性至關重要,而僅僅用POST請求提交用戶的隱私數據,還是不能完全解決安全問題。因此:提交用戶的隱私數據時,一定不要明文提交,要加密處理后再提交。
常見的加密算法
MD5 \ SHA \ DES \ 3DES \ RC2和RC4 \ RSA \ IDEA \ DSA \ AES
加密算法的選擇
一般公司都會有一套自己的加密方案,按照公司接口文檔的規定去加密。
MD5簡介
簡單說明:
MD5:全稱是Message Digest Algorithm 5,譯為“消息摘要算法第5版”
效果:對輸入信息生成唯一的128位散列值(32個字符)
MD5生成的是固定的128bit,即128個0和1的二進制位,而在實際應用開發中,通常是以16進制輸出的,所以正好就是32位的16進制,說白了也就是32個16進制的數字。MD5的特點:
(1)輸入兩個不同的明文不會得到相同的輸出值
(2)根據輸出值,不能得到原始的明文,即其過程不可逆(只能加密, 不能解密)MD5的應用:
由于MD5加密算法具有較好的安全性,而且免費,因此該加密算法被廣泛使用
大多數的登錄功能向后臺提交密碼時都會使用到這種算法注意點:
(1)一定要和后臺開發人員約定好,MD5加密的位數是16位還是32位(大多數都是32位的),16位的可以通過32位的轉換得到。
(2)MD5加密區分 大小寫,使用時要和后臺約定好。MD5解密:
解密網站: http://www.cmd5.com/
MD5代碼:
自定義一個繼承自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{
//要進行UTF8的轉碼
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{
//要進行UTF8的轉碼
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
使用:
- 導入MD5Tool.h
- 調用類方法:
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加密就這么搞定了, 可以通過上面的解密網站測試自己的加密是否正確!!!
<br />
<br />
GitHub: https://github.com/LiCheng244/LCUtils
個人博客: http://www.licheng244.com/