iOS 数据加密(3DES/CBC/PKCS5Padding)

  • 3DES(或称为Triple DES)是DES加密算法的一种模式、是三重数据加密算法(TDEA,Triple Data Encryption Algorithm)块密码的通称。它相当于是对每个数据块(先将数据分成固定长度的小数据块,之后进行加密)应用三次DES加密算法。由于计算机运算能力的增强,原版DES密码的密钥长度变得容易被暴力破解;3DES即是设计用来提供一种相对简单的方法,即通过增加DES的密钥长度来避免类似的攻击,而不是设计一种全新的块密码算法。它使用3条56位的密钥对数据进行三次加密。数据加密标准(DES)是美国的一种由来已久的加密标准,它使用对称密钥加密法,并于1981年被ANSI组织规范为ANSI X.3.92。DES使用56位密钥和密码块的方法,而在密码块的方法中,文本被分成64位大小的文本块然后再进行加密。比起最初的DES,3DES更为安全。简单的理解就是对DES加密三次,通过增加DES的密钥长度来避免暴力破解。

  • iOS 7后苹果增加了 CCCrypt函数不需要引入第三方,直接引入 #import <CommonCrypto/CommonCryptor.h>就可以使用3DES加密。

  • 使用加密我们主要关注加密模式和填充方式,至于密码和偏移量一般后台会给。下文使用的是3DES算法加密,CBC加密模式和PKCS5Padding填充方式。

//密匙 key

#define gkey            @"loprdkldloprdkldloprdkld"

//偏移量

#define gIv             @“12345678"

#import <CommonCrypto/CommonCryptor.h>

//十六进制
+ (NSString *)doEncryptHex:(NSString *)originalStr{
    //把string 转NSData
    NSData* data = [originalStr dataUsingEncoding:NSUTF8StringEncoding];
    //length
    size_t plainTextBufferSize = [data length];
    
    const void *vplainText = (const void *)[data bytes];
    
    CCCryptorStatus ccStatus;
    uint8_t *bufferPtr = NULL;
    size_t bufferPtrSize = 0;
    size_t movedBytes = 0;
    
    bufferPtrSize = (plainTextBufferSize + kCCBlockSize3DES) & ~(kCCBlockSize3DES - 1);
    bufferPtr = malloc( bufferPtrSize * sizeof(uint8_t));
    memset((void *)bufferPtr, 0x0, bufferPtrSize);
    
    const void *vkey = (const void *) [gkey UTF8String];
    //偏移量
    const void *vinitVec = (const void *) [gIv UTF8String];
    //配置CCCrypt
    ccStatus = CCCrypt(kCCEncrypt,
                       kCCAlgorithm3DES, //使用3DES加密算法
                       kCCOptionPKCS7Padding, //设置填充模式
                       vkey,    //key 此处key的长度 和下面参数指定的长度要相同
                       kCCKeySize3DES,//key的长度为24位,所以  vkey必须是24位长度
                       vinitVec,     //偏移量,这里不用,设置为nil;不用的话,必须为nil,不可以为@“” ECB模式不用设置偏移量
                       vplainText,
                       plainTextBufferSize,
                       (void *)bufferPtr,
                       bufferPtrSize,
                       &movedBytes);
    NSMutableString *hexString = [[NSMutableString alloc] init];


    if (ccStatus == kCCSuccess) {
        NSData *myData = [NSData dataWithBytes:(const char *)bufferPtr length:(NSUInteger)movedBytes];
//        NSString *result = [GTMBase64 stringByEncodingData:myData];//或者输出为base64
        NSUInteger          len = [myData length];
        char *              chars = (char *)[myData bytes];
        for(NSUInteger i = 0; i < len; i++ ){
            [hexString appendString:[NSString stringWithFormat:@"%0.2hhx", chars[i]]];
        }
    }    
    return hexString;  
}

CCCrypt函数参数解析

  • 第一个参数(kCCEncrypt)告诉程序是加密还是解密

  • 第二个参数(kCCAlgorithm3DES)告诉程序使用的是3DES加密算法。

  • 第三个参数设置的是填充模式,其中kCCOptionPKCS7Padding对应于CBC使用PKCS7Padding的填充模式进行加密,kCCOptionPKCS7Padding | kCCOptionECBMode表示运用了ECB加密模式。

  • 第四个参数(vkey)秘钥

  • 第五个参数(kCCKeySize3DES)指定秘钥的长度,这个值和第二个加密方式对应的kCCAlgorithm3DES对应的就是24位的kCCKeySize3DES。如果是kCCAlgorithmDES则对应8位的kCCKeySizeDES,以此类推。可以直接点进函数看看。

  • 第六个设置偏移量

  • 第七个是要加密的值

  • 第八个是要加密的值长度

  • 在线加密解密测试网站 http://tool.chacuo.net/crypt3des/

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,088评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,715评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,361评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,099评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 60,987评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,063评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,486评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,175评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,440评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,518评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,305评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,190评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,550评论 3 298
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,880评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,152评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,451评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,637评论 2 335