iOS开发之Objective-c的AES加密和解密算法的实现
来源:互联网 发布:linux自启动脚本 编辑:程序博客网 时间:2024/06/05 12:02
高级加密标准(Advanced Encryption Standard,AES),又称Rijndael加密法。
以下实现代码中分别为NSData和NSString增加了一个Category。使用时直接调用即可。
需要注意的是,AES并不能作为HASH算法,加密并解密后的结果,并不一定与原文相同,使用时请注意进行结果验算。例如解密原文的长度,格式规则等。
NG实例
原文:170987350密码:170
Objective-c的AES加密和解密算法的具体实现代码如下:
1.拓展NSData,增加AES256加密方法
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
////NSData+AES256.h// #import <Foundation/Foundation.h>#import <CommonCrypto/CommonDigest.h>#import <CommonCrypto/CommonCryptor.h> @interface NSData(AES256)-(NSData *) aes256_encrypt:(NSString *)key;-(NSData *) aes256_decrypt:(NSString *)key;@end ////NSData+AES256.m//#import "NSData+AES256.h" @implementation NSData(AES256) - (NSData *)aes256_encrypt:(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; void *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 *)aes256_decrypt:(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; void *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;}@end
2.拓展NSString,增加AES256加密方法,需要导入NSData+AES256.h
12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
////NSString +AES256.h// #import <Foundation/Foundation.h>#import <CommonCrypto/CommonDigest.h>#import <CommonCrypto/CommonCryptor.h> #import "NSData+AES256.h" @interface NSString(AES256) -(NSString *) aes256_encrypt:(NSString *)key;-(NSString *) aes256_decrypt:(NSString *)key; @end ////NSString +AES256.h// @implementation NSString(AES256) -(NSString *) aes256_encrypt:(NSString *)key{ const char *cstr = [self cStringUsingEncoding:NSUTF8StringEncoding]; NSData *data = [NSData dataWithBytes:cstr length:self.length]; //对数据进行加密 NSData *result = [data aes256_encrypt:key]; //转换为2进制字符串 if (result && result.length > 0) { Byte *datas = (Byte*)[result bytes]; NSMutableString *output = [NSMutableString stringWithCapacity:result.length * 2]; for(int i = 0; i < result.length; i++){ [output appendFormat:@"%02x", datas[i]]; } return output; } return nil;} -(NSString *) aes256_decrypt:(NSString *)key{ //转换为2进制Data NSMutableData *data = [NSMutableData dataWithCapacity:self.length / 2]; unsigned char whole_byte; char byte_chars[3] = {'\0','\0','\0'}; int i; for (i=0; i < [self length] / 2; i++) { byte_chars[0] = [self characterAtIndex:i*2]; byte_chars[1] = [self characterAtIndex:i*2+1]; whole_byte = strtol(byte_chars, NULL, 16); [data appendBytes:&whole_byte length:1]; } //对数据进行解密 NSData* result = [data aes256_decrypt:key]; if (result && result.length > 0) { return [[NSString alloc] initWithData:result encoding:NSUTF8StringEncoding]autorelease]; } return nil;}@end
0 0
- iOS开发之Objective-c的AES加密和解密算法的实现
- iOS开发之Objective-c的AES加密和解密算法的实现
- iOS开发之Objective-c的AES加密和解密算法的实现
- iOS开发-Objective-c的AES加密和解密算法的实现
- AES加密解密算法的C代码实现
- AES加密解密算法的C代码实现
- JAVA实现AES的加密和解密算法
- AES加密解密算法的Java实现
- iOS开发之Objective-c的加密的实现
- iOS AES的加密解密
- iOS AES的加密解密
- ios开发之Objective-C中BASE64编码加密解密的使用
- ios开发之Objective-C中BASE64编码加密解密的使用
- iOS开发之Objective-C中BASE64编码加密解密的使用
- C语言实现AES算法加密/解密算法---以前写的,整理下
- java实现对称加密AES和DES的加密、解密
- AES加密解密算法的FPGA实现(一)
- AES加密解密算法的FPGA实现(二)
- 剑指Offer 面试题3:二维数组中查找
- java学习笔记之String 构造方法
- leetcode ||131、Palindrome Partitioning
- Spring基础的学习(一)
- AssetBundle机制相关资料收集
- iOS开发之Objective-c的AES加密和解密算法的实现
- js 面向对象,多重创建对象方法
- Oracle带输出参数的存储过程和调用
- log4j2 使用详解
- Spark连接数据库方法
- 1到正整数N中所有整数中1的个数
- NGUI用UIGrid加载Item会有部分空出来的解决办法
- android代码混淆,打包签名出错
- jquery 网页滚动到底部自动加载