iOS系统方法进行AES对称加密

废话不多说,直接上代码:

头文件:

[objc]  view plain  copy
 print ? 在CODE上查看代码片 派生到我的代码片
  1. #import <Foundation/Foundation.h>  
  2.   
  3. @class NSString;  
  4.   
  5. @interface NSData (Encryption)  
  6.   
  7. - (NSData *)AES256ParmEncryptWithKey:(NSString *)key;   //加密  
  8. - (NSData *)AES256ParmDecryptWithKey:(NSString *)key;   //解密  
  9.   
  10. @end  


.m实现文件:

[objc]  view plain  copy
 print ? 在CODE上查看代码片 派生到我的代码片
  1. #import "Encryption.h"  
  2. #import <CommonCrypto/CommonCryptor.h>  
  3.   
  4. @implementation NSData (Encryption)  
  5.   
  6. - (NSData *)AES256ParmEncryptWithKey:(NSString *)key   //加密  
  7. {  
  8.     char keyPtr[kCCKeySizeAES256+1];  
  9.     bzero(keyPtr, sizeof(keyPtr));  
  10.     [key getCString:keyPtr maxLength:sizeof(keyPtr) encoding:NSUTF8StringEncoding];  
  11.     NSUInteger dataLength = [self length];  
  12.     size_t bufferSize = dataLength + kCCBlockSizeAES128;  
  13.     voidvoid *buffer = malloc(bufferSize);  
  14.     size_t numBytesEncrypted = 0;  
  15.     CCCryptorStatus cryptStatus = CCCrypt(kCCEncrypt, kCCAlgorithmAES128,  
  16.                                           kCCOptionPKCS7Padding | kCCOptionECBMode,  
  17.                                           keyPtr, kCCBlockSizeAES128,  
  18.                                           NULL,  
  19.                                           [self bytes], dataLength,  
  20.                                           buffer, bufferSize,  
  21.                                           &numBytesEncrypted);  
  22.     if (cryptStatus == kCCSuccess) {  
  23.         return [NSData dataWithBytesNoCopy:buffer length:numBytesEncrypted];  
  24.     }  
  25.     free(buffer);  
  26.     return nil;  
  27. }  
  28.   
  29.   
  30. - (NSData *)AES256ParmDecryptWithKey:(NSString *)key   //解密  
  31. {  
  32.     char keyPtr[kCCKeySizeAES256+1];  
  33.     bzero(keyPtr, sizeof(keyPtr));  
  34.     [key getCString:keyPtr maxLength:sizeof(keyPtr) encoding:NSUTF8StringEncoding];  
  35.     NSUInteger dataLength = [self length];  
  36.     size_t bufferSize = dataLength + kCCBlockSizeAES128;  
  37.     voidvoid *buffer = malloc(bufferSize);  
  38.     size_t numBytesDecrypted = 0;  
  39.     CCCryptorStatus cryptStatus = CCCrypt(kCCDecrypt, kCCAlgorithmAES128,  
  40.                                           kCCOptionPKCS7Padding | kCCOptionECBMode,  
  41.                                           keyPtr, kCCBlockSizeAES128,  
  42.                                           NULL,  
  43.                                           [self bytes], dataLength,  
  44.                                           buffer, bufferSize,  
  45.                                           &numBytesDecrypted);  
  46.     if (cryptStatus == kCCSuccess) {  
  47.         return [NSData dataWithBytesNoCopy:buffer length:numBytesDecrypted];  
  48.     }  
  49.     free(buffer);  
  50.     return nil;  
  51. }  
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值