最近項(xiàng)目中要求用des加密 , 之前沒(méi)有用到過(guò), 查了很多資料,為了給大家節(jié)省時(shí)間 直接上代碼 des首先要用到GTMBase64,github上就能下載,主要要到GTMBase64.h,GTMBase64.m,GTMDefines這三個(gè).
下面的復(fù)制過(guò)去就可以用了 不過(guò)在弄得時(shí)候要注意 一些字典轉(zhuǎn)jsonstring 或者 jsonstring轉(zhuǎn)字典 你可能會(huì)用到.
.h中
#import#import "GTMBase64.h"#import@interface DES : NSObject
+ (NSString *)encryptWithText:(NSString *)sText;//加密
+ (NSString *)decryptWithText:(NSString *)sText;//解密
+ (NSString*)dictionaryToJson:(NSDictionary *)dic;
.m中
#import "DES.h"
@implementation DES
+ (NSString*)dictionaryToJson:(NSDictionary *)dic
{
NSError *parseError = nil;
NSData *jsonData = [NSJSONSerialization dataWithJSONObject:dic options:NSJSONWritingPrettyPrinted error:&parseError];
return [[NSString alloc] initWithData:jsonData encoding:NSUTF8StringEncoding];
}
+ (NSString *)encryptWithText:(NSString *)sText
{
//kCCEncrypt 加密
return [self encrypt:sText encryptOrDecrypt:kCCEncrypt key:@"跟后臺(tái)商量好的key"];
}
+ (NSString *)decryptWithText:(NSString *)sText
{
//kCCDecrypt 解密
return [self encrypt:sText encryptOrDecrypt:kCCDecrypt key:@"跟后臺(tái)商量好的key"];
}
+ (NSString *)encrypt:(NSString *)sText encryptOrDecrypt:(CCOperation)encryptOperation key:(NSString *)key
{
const void *dataIn;
size_t dataInLength;
if (encryptOperation == kCCDecrypt)//傳遞過(guò)來(lái)的是decrypt 解碼
{
//解碼 base64
NSData *decryptData = [GTMBase64 decodeData:[sText dataUsingEncoding:NSUTF8StringEncoding]];//轉(zhuǎn)成utf-8并decode
dataInLength = [decryptData length];
dataIn = [decryptData bytes];
}
else? //encrypt
{
NSData* encryptData = [sText dataUsingEncoding:NSUTF8StringEncoding];
dataInLength = [encryptData length];
dataIn = (const void *)[encryptData bytes];
}
/*
DES加密 :用CCCrypt函數(shù)加密一下狡逢,然后用base64編碼下,傳過(guò)去
DES解密 :把收到的數(shù)據(jù)根據(jù)base64,decode一下,然后再用CCCrypt函數(shù)解密,得到原本的數(shù)據(jù)
*/
CCCryptorStatus ccStatus;
uint8_t *dataOut = NULL; //可以理解位type/typedef 的縮寫(有效的維護(hù)了代碼父丰,比如:一個(gè)人用int斧账,一個(gè)人用long玻靡。最好用typedef來(lái)定義)
size_t dataOutAvailable = 0; //size_t? 是操作符sizeof返回的結(jié)果類型
size_t dataOutMoved = 0;
dataOutAvailable = (dataInLength + kCCBlockSizeDES) & ~(kCCBlockSizeDES - 1);
dataOut = malloc( dataOutAvailable * sizeof(uint8_t));
memset((void *)dataOut, 0x0, dataOutAvailable);//將已開(kāi)辟內(nèi)存空間buffer的首 1 個(gè)字節(jié)的值設(shè)為值 0
NSString *initIv = @"跟后臺(tái)商量好的iv";
const void *vkey = (const void *) [key UTF8String];
const void *iv = (const void *) [initIv UTF8String];
//CCCrypt函數(shù) 加密/解密
ccStatus = CCCrypt(encryptOperation,//? 加密/解密
kCCAlgorithmDES,//? 加密根據(jù)哪個(gè)標(biāo)準(zhǔn)(des著蟹,3des,aes梢莽。萧豆。。昏名。)
kCCOptionPKCS7Padding,//? 選項(xiàng)分組密碼算法(des:對(duì)每塊分組加一次密? 3DES:對(duì)每塊分組加三個(gè)不同的密)
vkey,? //密鑰? ? 加密和解密的密鑰必須一致
kCCKeySizeDES,//? DES 密鑰的大袖汤住(kCCKeySizeDES=8)
iv, //? 可選的初始矢量
dataIn, // 數(shù)據(jù)的存儲(chǔ)單元
dataInLength,// 數(shù)據(jù)的大小
(void *)dataOut,// 用于返回?cái)?shù)據(jù)
dataOutAvailable,
&dataOutMoved);
NSString *result = nil;
if (encryptOperation == kCCDecrypt)//encryptOperation==1? 解碼
{
//得到解密出來(lái)的data數(shù)據(jù),改變?yōu)閡tf-8的字符串
result = [[NSString alloc] initWithData:[NSData dataWithBytes:(const void *)dataOut length:(NSUInteger)dataOutMoved] encoding:NSUTF8StringEncoding];
}
else //encryptOperation==0? (加密過(guò)程中轻局,把加好密的數(shù)據(jù)轉(zhuǎn)成base64的)
{
//編碼 base64
NSData *data = [NSData dataWithBytes:(const void *)dataOut length:(NSUInteger)dataOutMoved];
result = [GTMBase64 stringByEncodingData:data];
}
return result;
}