CCCrypt函数的dataOut参数和dataOutAvailable参数

第八个参数:dataOut:

处理后的结果回传给此参数。
注意,此值必须能放下输出的结果,否则函数调用失败。

第9个参数:size_t dataOutAvailable 
指第九个参数void *dataOut的长度。
注意:必须和第9个参数的实际长度一致。c语言不能由指针求出长度,所以必须指定长度。

按网上的很多例子,如下,使用1024的固定值,在输出结果大于1024字节时会失败:

 unsigned char buffer[1024];
 memset(buffer, 0, sizeof(char));

 size_t numBytesDecrypted = 0;


开发时虽然觉得此处用一个固定值感觉有不妥,
但以为会想oc的数组一样,在内容超出时会自动扩容。
因为测试时测试数据都很短,没有问题,结果上线以后就悲剧了。


下面是DES解密时,dataOut长度的计算:

+(NSString *)decryptUseDESWithKey:(NSString*)key encryptedStr:(NSString*)encryptedStr{
    NSData *cipherKeyData = [[NSData alloc] initWithBase64EncodedString:key options:0];
    NSData *cipherData = [[NSData alloc] initWithBase64EncodedString:encryptedStr options:0];
    
   //求buffer的长度,buffer必须能容下解密后的数据,否则解密会失败。
    NSUInteger dataLength = [cipherData length];
    unsigned long bufferPtrSize = (dataLength + kCCBlockSizeDES) & ~(kCCBlockSizeDES - 1);
    unsigned char buffer[bufferPtrSize];
    memset(buffer, 0, sizeof(char));
    
    
    size_t numBytesDecrypted = 0;
    CCCryptorStatus cryptStatus = CCCrypt(kCCDecrypt,
                                          kCCAlgorithmDES,
                                          kCCOptionPKCS7Padding | kCCOptionECBMode,
                                          [cipherKeyData bytes],
                                          kCCKeySizeDES,
                                          NULL,
                                          [cipherData bytes],
                                          [cipherData length],
                                          buffer,
                                          bufferPtrSize,
                                          &numBytesDecrypted);
    NSString* plainText = nil;
    if (cryptStatus == kCCSuccess) {
        NSData* data = [NSData dataWithBytes:buffer length:(NSUInteger)numBytesDecrypted];
        plainText = [[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding];
    }
    return plainText;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值