AES+128+CBC数据加密 IOS及PHP

一.AES+128+CBC  加密

128加密算法长度

CBC加密方式

1.继承NSData写一个扩展。如下:有相关注释哦~

- (NSData *)AES256EncryptWithKey:(NSString *)key//加密

{

    //AES的密钥长度256字节

    char keyPtr[kCCKeySizeAES256+1];

    bzero(keyPtr, sizeof(keyPtr));

    [key getCString:keyPtr maxLength:sizeof(keyPtr) encoding:NSUTF8StringEncoding];


    char ivPtr[kCCKeySizeAES256+1];

    memset(ivPtr, 0, sizeof(ivPtr));

    [APP_PUBLIC_IV getCString:ivPtr maxLength:sizeof(ivPtr) encoding:NSUTF8StringEncoding];


    //密文的长度

    NSUInteger dataLength = [self length];

    //密文长度+补位长度

    size_t bufferSize = dataLength + kCCKeySizeAES256;

    //为加密结果开辟空间

    void *buffer = malloc(bufferSize);

    size_t numBytesEncrypted = 0;


    /* kCCDecrypt:加密/解密

    * kCCAlgorithmAES128:加密方式

    * kCCOptionPKCS7Padding | kCCOptionECBMode:工作模式

    * keyPtr:UTF-8格式的key

    * kCCKeySizeAES256:按32位长度解密

    * iv:私钥

    * [self bayes]:密文

    * ...

    */

    CCCryptorStatus cryptStatus = CCCrypt(kCCEncrypt,

                                          kCCAlgorithmAES128,

                                          kCCOptionPKCS7Padding | kCCOptionECBMode,

                                          keyPtr,

                                          kCCKeySizeAES256,

                                          ivPtr,

                                          [self bytes],

                                          dataLength,

                                          buffer,

                                          bufferSize,

                                          &numBytesEncrypted);

    if (cryptStatus == kCCSuccess) {

        return [NSData dataWithBytesNoCopy:buffer length:numBytesEncrypted];

    }

    free(buffer);

    return nil;

}

- (NSData *)AES256DecryptWithKey:(NSString *)key//解密

{

    char keyPtr[kCCKeySizeAES256+1];

    bzero(keyPtr, sizeof(keyPtr));

    [key getCString:keyPtr maxLength:sizeof(keyPtr) encoding:NSUTF8StringEncoding];


    char ivPtr[kCCKeySizeAES256+1];

    memset(ivPtr, 0, sizeof(ivPtr));

    [APP_PUBLIC_IV getCString:ivPtr maxLength:sizeof(ivPtr) encoding:NSUTF8StringEncoding];


    NSUInteger dataLength = [self length];

    size_t bufferSize = dataLength + kCCKeySizeAES256;

    void *buffer = malloc(bufferSize);

    size_t numBytesDecrypted = 0;

    CCCryptorStatus cryptStatus = CCCrypt(kCCDecrypt,

                                          kCCAlgorithmAES128,

                                          kCCOptionPKCS7Padding | kCCOptionECBMode,

                                          keyPtr,

                                          kCCKeySizeAES256,

                                          ivPtr,

                                          [self bytes],

                                          dataLength,

                                          buffer,

                                          bufferSize,

                                          &numBytesDecrypted);

    if (cryptStatus == kCCSuccess) {

        return [NSData dataWithBytesNoCopy:buffer length:numBytesDecrypted];

    }

    free(buffer);

    return nil;

}

2.使用方法

NSString *test = @"abcdefghijklmnopqrstuvwxyz";

NSString *aesData = [SecurityUtil encryptAESData:test];

NSLog(@"AES加密:%@", aesData);

NSString *enstr = [SecurityUtil decryptAESData:aesData];

NSLog(@"AES解密:%@",enstr);


二.AES+256+CFB  加密


#pragma mark - CFB加密

+ (NSString *)encryptAESCBC:(NSString *)inputString

{

NSMutableData *inputData = [NSMutableData dataWithData: [inputString dataUsingEncoding: NSUTF8StringEncoding]];

NSData *outData = [self CBCWithOperation:kCCEncrypt andIv:APP_PUBLIC_IV andKey:APP_PUBLIC_KEY andInput: inputData];

outData = [outData base64EncodedDataWithOptions:NSDataBase64EncodingEndLineWithLineFeed];

  return [[NSString alloc] initWithData:outData encoding: NSUTF8StringEncoding] ?: @"";

}

#pragma mark - CFB解密

+ (NSString *)decryptAESCBC:(NSString *)outputString

{

    NSData *data = [GTMBase64 decodeString:outputString];

    NSData *outData = [self CBCWithOperation:kCCDecrypt andIv:APP_PUBLIC_IV andKey:APP_PUBLIC_KEY andInput:data];

    //将解了密码的nsdata转化为nsstring

    NSString *result = [[NSString alloc] initWithData:outData encoding:NSUTF8StringEncoding];

    return result;

}

核心代码如下:

+ (NSData *)CBCWithOperation:(CCOperation)operation andIv:(NSString *)ivString andKey:(NSString *)keyString andInput:(NSData *)inputData

{

    const char *iv = [[ivString dataUsingEncoding: NSUTF8StringEncoding] bytes];        const char *key = [[keyString dataUsingEncoding: NSUTF8StringEncoding] bytes];

    CCCryptorRef cryptor;

    CCCryptorCreateWithMode(operation, kCCModeCFB, kCCAlgorithmAES, ccNoPadding, iv, key, [keyString length], NULL, 0, 0, 0, &cryptor);

    NSUInteger inputLength = inputData.length;

    char *outData = malloc(inputLength);

    memset(outData, 0, inputLength);

    size_t outLength = 0;

    CCCryptorUpdate(cryptor, inputData.bytes, inputLength, outData, inputLength, &outLength);

    NSData *data = [NSData dataWithBytes: outData length: outLength];

    CCCryptorRelease(cryptor);

    free(outData);

    return data;

}

使用方法:

NSString *str =  [NSData encryptAESCBC:test];

    NSLog(@"AES cfb加密:%@", str);

    NSString *str1 =  [NSData decryptAESCBC:str];

    NSLog(@"AES cfb解密:%@",str1);


有什么地方看不懂的可以私聊哦~  QQ:154235507

最近比较忙,没有时间上传代码到github上,有需要源文件的也可以私聊哦~

之后有时间的话,会上传demo。

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

推荐阅读更多精彩内容