3.通过AES加密实例(基于c和oc)进一步了解指针

本文介绍了一种在iOS环境中实现AES加密解密的方法。通过使用CCCrypt框架,文章详细解释了内存分配、指针操作及加密过程。具体包括:(1)利用malloc函数分配内存;(2)通过指针传递加密后的数据;(3)设置输出尺寸;(4)从内存地址创建NSData对象;(5)释放分配的内存。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

/*
 
   AES加密解密中用到的指针知识——ios,看(1)、(2)、(3)、(4)、(5)
 
*/

NSData * cipherOperation(NSData *contentData, NSData *keyData, CCOperation operation) {
   


    /*
    
     void的字面意思是“无类型”,void *则为“无类型指针”,void *可以指向任何类型的数据。const之后的值,对应着常量
            
     */


    void const *initVectorBytes = [kInitVector dataUsingEncoding:NSUTF8StringEncoding].bytes;
   

    void const *contentBytes = contentData.bytes;
   

    void const *keyBytes = keyData.bytes;
   
   
    NSUInteger dataLength = contentData.length;
   
    //本身长度 +为了防止最后一个明(密)文块不完整,所以加上16bytes
    size_t operationSize = dataLength + kCCBlockSizeAES128;
   


   
    //(1)内存自动分配函数,最后得到的是一个自动分配的存储区,operationBytes是地址,此存储区的初始内容不确定,如果失败返回NULL
    void *operationBytes = malloc(operationSize);
   
   
    if (operationBytes == NULL) {
        return nil;
    }
    //初始化输出尺寸
    size_t actualOutSize = 0;
   

    //(2)我们传入的指针变量operationBytes实际上对应的是存储区的地址,当然我们要在加密方法中,在地址中放入密文块或者名文块,方便后期获取,返回值是一个状态

    //(3)把actualOutSize取地址放到函数内,在函数中对地址中对应的数字进行操作,最后我们得到的是输出时候的长度

    CCCryptorStatus cryptStatus = CCCrypt(operation,
                                          kCCAlgorithmAES,
                                          kCCOptionPKCS7Padding,
                                          keyBytes,
                                          kKeySize,
                                          initVectorBytes,
                                          contentBytes,
                                          dataLength,
                                          operationBytes,
                                          operationSize,
                                          &actualOutSize);
   
    //如果判断状态是成功的话
    if (cryptStatus == kCCSuccess) {
      //(4)从一个给定的给定字节数的存储区地址,创建并返回一个数据对象。从存储区地址获取存储区内容,内容在CCCrypt方法中已经放好了 operationBytes本身是一个地址

        return [NSData dataWithBytesNoCopy:operationBytes length:actualOutSize];
    }
   
   
    //(5)malloc()函数自动分配内存,最后是一定要释放的
    free(operationBytes);
    operationBytes = NULL;

    return nil;
   
   
   
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值