iOS开发 单AES加密/解密
2020-08-11 17:58
1181 查看
+(NSData *)AES256ParmEncryptWithKey:(NSString *)key Encrypttext:(NSData *)text //加密 { char keyPtr[kCCKeySizeAES256+1]; bzero(keyPtr, sizeof(keyPtr)); [key getCString:keyPtr maxLength:sizeof(keyPtr) encoding:NSUTF8StringEncoding]; NSUInteger dataLength = [text length]; size_t bufferSize = dataLength + kCCBlockSizeAES128; void *buffer = malloc(bufferSize); size_t numBytesEncrypted = 0; CCCryptorStatus cryptStatus = CCCrypt(kCCEncrypt, kCCAlgorithmAES128, kCCOptionPKCS7Padding | kCCOptionECBMode, keyPtr, kCCBlockSizeAES128, NULL, [text bytes], dataLength, buffer, bufferSize, &numBytesEncrypted); if (cryptStatus == kCCSuccess) { return [NSData dataWithBytesNoCopy:buffer length:numBytesEncrypted]; } free(buffer); return nil; } + (NSData *)AES256ParmDecryptWithKey:(NSString *)key Decrypttext:(NSData *)text //解密 { char keyPtr[kCCKeySizeAES256+1]; bzero(keyPtr, sizeof(keyPtr)); [key getCString:keyPtr maxLength:sizeof(keyPtr) encoding:NSUTF8StringEncoding]; NSUInteger dataLength = [text length]; size_t bufferSize = dataLength + kCCBlockSizeAES128; void *buffer = malloc(bufferSize); size_t numBytesDecrypted = 0; CCCryptorStatus cryptStatus = CCCrypt(kCCDecrypt, kCCAlgorithmAES128, kCCOptionPKCS7Padding | kCCOptionECBMode, keyPtr, kCCBlockSizeAES128, NULL, [text bytes], dataLength, buffer, bufferSize, &numBytesDecrypted); if (cryptStatus == kCCSuccess) { return [NSData dataWithBytesNoCopy:buffer length:numBytesDecrypted]; } free(buffer); return nil; } +(NSString *) aes256_encrypt:(NSString *)key Encrypttext:(NSString *)text { const char *cstr = [text cStringUsingEncoding:NSUTF8StringEncoding]; NSData *data = [NSData dataWithBytes:cstr length:text.length]; //对数据进行加密 NSData *result = [LanAES AES256ParmEncryptWithKey:key Encrypttext:data]; // 转换为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 Decrypttext:(NSString *)text { // 转换为2进制Data NSMutableData *data = [NSMutableData dataWithCapacity:text.length / 2]; unsigned char whole_byte; char byte_chars[3] = {'\0','\0','\0'}; int i; for (i=0; i < [text length] / 2; i++) { byte_chars[0] = [text characterAtIndex:i*2]; byte_chars[1] = [text characterAtIndex:i*2+1]; whole_byte = strtol(byte_chars, NULL, 16); [data appendBytes:&whole_byte length:1]; } // 对数据进行解密 NSData* result = [LanAES AES256ParmDecryptWithKey:key Decrypttext:data]; if (result && result.length > 0) { return [[NSString alloc] initWithData:result encoding:NSUTF8StringEncoding]; } return nil; }
相关文章推荐
- iOS开发之Objective-c的AES加密和解密算法的实现
- iOS开发之Objective-c的AES加密和解密算法的实现
- iOS开发-Objective-c的AES加密和解密算法的实现
- iOS开发之Objective-c的AES加密和解密算法的实现
- iOS开发之Objective-c的AES加密和解密算法的实现
- iOS开发之AES+Base64数据混合加密与解密
- iOS开发--AES加密中的那些坑
- android、ios、php之间AES加密解密
- iOS开发--AES加密中的那些坑
- iOS AES加密解密实现方法
- iOS开发:base64简单的加密和解密使用
- iOS AES加密解密的使用
- AES加密解密,iOS,Android,Java,.Net通用
- iOS开发(93)之常用加密方法(aes、md5、base64)
- iOS开发之AES+Base64数据混合加密与解密
- IOS开发之—— 各种加密的使用(MD5,base64,DES,AES)
- iOS AES的加密解密
- PHP开发过程中AES加密解密问题 js前端AES加密,PHP解密
- php,android,ios 之间 AES加密解密
- android、ios、php之间AES加密解密