DES加密 解密

最近项目中要求用des加密 , 之前没有用到过, 查了很多资料,为了给大家节省时间 直接上代码 des首先要用到GTMBase64,github上就能下载,主要要到GTMBase64.h,GTMBase64.m,GTMDefines这三个.

下面的复制过去就可以用了 不过在弄得时候要注意 一些字典转jsonstring 或者 jsonstring转字典 你可能会用到.

.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:@"跟后台商量好的key"];

}

+ (NSString *)decryptWithText:(NSString *)sText

{

//kCCDecrypt 解密

return [self encrypt:sText encryptOrDecrypt:kCCDecrypt key:@"跟后台商量好的key"];

}

+ (NSString *)encrypt:(NSString *)sText encryptOrDecrypt:(CCOperation)encryptOperation key:(NSString *)key

{

const void *dataIn;

size_t dataInLength;

if (encryptOperation == kCCDecrypt)//传递过来的是decrypt 解码

{

//解码 base64

NSData *decryptData = [GTMBase64 decodeData:[sText dataUsingEncoding:NSUTF8StringEncoding]];//转成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函数加密一下,然后用base64编码下,传过去

DES解密 :把收到的数据根据base64,decode一下,然后再用CCCrypt函数解密,得到原本的数据

*/

CCCryptorStatus ccStatus;

uint8_t *dataOut = NULL; //可以理解位type/typedef 的缩写(有效的维护了代码,比如:一个人用int,一个人用long。最好用typedef来定义)

size_t dataOutAvailable = 0; //size_t  是操作符sizeof返回的结果类型

size_t dataOutMoved = 0;

dataOutAvailable = (dataInLength + kCCBlockSizeDES) & ~(kCCBlockSizeDES - 1);

dataOut = malloc( dataOutAvailable * sizeof(uint8_t));

memset((void *)dataOut, 0x0, dataOutAvailable);//将已开辟内存空间buffer的首 1 个字节的值设为值 0

NSString *initIv = @"跟后台商量好的iv";

const void *vkey = (const void *) [key UTF8String];

const void *iv = (const void *) [initIv UTF8String];

//CCCrypt函数 加密/解密

ccStatus = CCCrypt(encryptOperation,//  加密/解密

kCCAlgorithmDES,//  加密根据哪个标准(des,3des,aes。。。。)

kCCOptionPKCS7Padding,//  选项分组密码算法(des:对每块分组加一次密  3DES:对每块分组加三个不同的密)

vkey,  //密钥    加密和解密的密钥必须一致

kCCKeySizeDES,//  DES 密钥的大小(kCCKeySizeDES=8)

iv, //  可选的初始矢量

dataIn, // 数据的存储单元

dataInLength,// 数据的大小

(void *)dataOut,// 用于返回数据

dataOutAvailable,

&dataOutMoved);

NSString *result = nil;

if (encryptOperation == kCCDecrypt)//encryptOperation==1  解码

{

//得到解密出来的data数据,改变为utf-8的字符串

result = [[NSString alloc] initWithData:[NSData dataWithBytes:(const void *)dataOut length:(NSUInteger)dataOutMoved] encoding:NSUTF8StringEncoding];

}

else //encryptOperation==0  (加密过程中,把加好密的数据转成base64的)

{

//编码 base64

NSData *data = [NSData dataWithBytes:(const void *)dataOut length:(NSUInteger)dataOutMoved];

result = [GTMBase64 stringByEncodingData:data];

}

return result;

}

你可能感兴趣的:(DES加密 解密)