IOS学习 CCCrypt加密和解密

- (NSData *)DESDecrypt:(NSData *)data WithKey:(NSString *)key encryptOrDecrypt:(CCOperation)encryptOperation

{

    char keyPtr[kCCKeySizeAES256+1];

    bzero(keyPtr, sizeof(keyPtr));

    

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

    

    NSUInteger dataLength = [data length];

    

//    size_t bufferSize = dataLength + kCCBlockSizeDES;

    size_t bufferSize = (dataLength + kCCBlockSizeDES) & ~(kCCBlockSizeDES - 1);

    

//    unsigned char buffer[(bufferSize * sizeof(char))];

//    memset(buffer, 0, sizeof(char));

    void *buffer = malloc(bufferSize * sizeof(char));

    

    size_t numBytesDecrypted = 0;

    CCCryptorStatus cryptStatus = CCCrypt(encryptOperation, kCCAlgorithmDES,

                                          kCCOptionPKCS7Padding,

                                          keyPtr, kCCBlockSizeDES,

                                          NULL,

                                          [data bytes], dataLength,

                                          buffer, bufferSize, 

                                          &numBytesDecrypted); 

//     | kCCOptionECBMode

    if (cryptStatus == kCCSuccess) {

        return [NSData dataWithBytesNoCopy:buffer length:numBytesDecrypted]; 

    } 

    

    free(buffer); 

    return nil

}


通过测试发现:kCCOptionPKCS7Padding与PKCS5Padding加密完成后的nsdata串时一样的,因此判断它们的填充方式是一样的。

测试例子在http://www.dnspod.cn/httpdns.guide下,接口API文档<<D+企业加密版本使用说明>>

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值