此方法采用kCCAlgorithmAES128,kCCOptionPKCS7Padding,kCCOptionECBMode,kCCBlockSizeAES128模式。如果另有其他模式需求加上即可!
废话不多说,直接上代码:
头文件:
-
#import <Foundation/Foundation.h>
-
#import <CommonCrypto/CommonCryptor.h>
-
@class NSString;
-
-
@interface NSData (Encryption)
-
-
- (NSData *)AES256ParmEncryptWithKey:(NSString *)key;
-
- (NSData *)AES256ParmDecryptWithKey:(NSString *)key;
-
-
@end
.m实现文件:
-
#import "Encryption.h"
-
#import <CommonCrypto/CommonCryptor.h>
-
-
@implementation NSData (Encryption)
-
-
- (NSData *)AES256ParmEncryptWithKey:(NSString *)key
-
{
-
char keyPtr[kCCKeySizeAES256+1];
-
bzero(keyPtr, sizeof(keyPtr));
-
[key getCString:keyPtr maxLength:sizeof(keyPtr) encoding:NSUTF8StringEncoding];
-
NSUInteger dataLength = [self length];
-
size_t bufferSize = dataLength + kCCBlockSizeAES128;
-
voidvoid *buffer = malloc(bufferSize);
-
size_t numBytesEncrypted = 0;
-
CCCryptorStatus cryptStatus = CCCrypt(kCCEncrypt, kCCAlgorithmAES128,
-
kCCOptionPKCS7Padding | kCCOptionECBMode,
-
keyPtr, kCCBlockSizeAES128,
-
NULL,
-
[self bytes], dataLength,
-
buffer, bufferSize,
-
&numBytesEncrypted);
-
if (cryptStatus == kCCSuccess) {
-
return [NSData dataWithBytesNoCopy:buffer length:numBytesEncrypted];
-
}
-
free(buffer);
-
return nil;
-
}
-
-
-
- (NSData *)AES256ParmDecryptWithKey:(NSString *)key
-
{
-
char keyPtr[kCCKeySizeAES256+1];
-
bzero(keyPtr, sizeof(keyPtr));
-
[key getCString:keyPtr maxLength:sizeof(keyPtr) encoding:NSUTF8StringEncoding];
-
NSUInteger dataLength = [self length];
-
size_t bufferSize = dataLength + kCCBlockSizeAES128;
-
voidvoid *buffer = malloc(bufferSize);
-
size_t numBytesDecrypted = 0;
-
CCCryptorStatus cryptStatus = CCCrypt(kCCDecrypt, kCCAlgorithmAES128,
-
kCCOptionPKCS7Padding | kCCOptionECBMode,
-
keyPtr, kCCBlockSizeAES128,
-
NULL,
-
[self bytes], dataLength,
-
buffer, bufferSize,
-
&numBytesDecrypted);
-
if (cryptStatus == kCCSuccess) {
-
return [NSData dataWithBytesNoCopy:buffer length:numBytesDecrypted];
-
}
-
free(buffer);
-
return nil;
-
}
版权声明:本文为博主原创文章,未经博主允许不得转载。
iOS系统方法进行AES对称加密
原文:http://blog.csdn.net/sinat_28709097/article/details/46872943