DES作为一种重要的对称加密算法,即使是iOS上也同样受到很大欢迎。这里介绍一下DES的CBC模式的iOS实现。至于ECB模式,这里有一篇文章来介绍,传送门->。
如果想了解更多模式,请看这里,传送门->。
不多说了,贴代码!
#import <Foundation/Foundation.h>
#import <CommonCrypto/CommonCryptor.h>
@interface NSString (DES)
+ (NSString *)DES_EncryptWithText:(NSString *)sText;
+ (NSString *)DES_DecryptWithText:(NSString *)sText;
+ (NSString *)DES_WithText:(NSString *)sText encryptOrDecrypt:(CCOperation)operation key:(NSString *)key;
@end
#import "NSString+DES.h"
@implementation NSString (DES)
+ (NSString *)DES_EncryptWithText:(NSString *)sText
{
//kCCEncrypt 加密
return [self DES_WithText:sText encryptOrDecrypt:kCCEncrypt key:@"des"];
}
+ (NSString *)DES_DecryptWithText:(NSString *)sText
{
//kCCDecrypt 解密
return [self DES_WithText:sText encryptOrDecrypt:kCCDecrypt key:@"des"];
}
+ (NSString *)DES_WithText:(NSString *)sText encryptOrDecrypt:(CCOperation)operation key:(NSString *)key
{
const void *dataIn;
size_t dataInLength;
if (operation == kCCDecrypt)// 解码
{
//解码 base64
NSData *decryptData = [[NSData alloc]initWithBase64EncodedString:sText options:NSDataBase64DecodingIgnoreUnknownCharacters];;//转成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;
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
const void *vkey = (const void *) [key UTF8String];
static Byte iv[] = {1,2,3,4,5,6,7,8}; //初始向量会影响最后加密出来的密文!
//CCCrypt函数 加密/解密
ccStatus = CCCrypt(operation,// 加密/解密
kCCAlgorithmDES,// 加密根据哪个标准(des,3des,aes。。。。)
kCCOptionPKCS7Padding,// 选项分组密码算法 默认是cbc模式
vkey, //密钥 加密和解密的密钥必须一致
kCCKeySizeDES,// DES 密钥的大小(kCCKeySizeDES=8)
iv, // 可选的初始矢量
dataIn, // 数据的存储单元
dataInLength,// 数据的大小
(void *)dataOut,// 用于返回数据
dataOutAvailable,
&dataOutMoved);
NSString *result = nil;
if (ccStatus == kCCSuccess) {
if (operation == kCCDecrypt)//encryptOperation==1 解码
{
//得到解密出来的data数据,改变为utf-8的字符串
result = [[NSString alloc] initWithData:[NSData dataWithBytes:(const void *)dataOut length:(NSUInteger)dataOutMoved] encoding:NSUTF8StringEncoding];
}
else
{
//加密 最后输出base64文本
NSData *data = [NSData dataWithBytes:(const void *)dataOut length:(NSUInteger)dataOutMoved];
result = [data base64EncodedStringWithOptions:NSDataBase64Encoding64CharacterLineLength];
}
}else
{
NSLog(@"加密or解密失败");
}
return result;
}
@end
文中关于初始向量iv的解释请看这里,传送门->。
另外,如果你想和java服务器一通协调工作,可以看看这里~传送门->。