iOS AES256加密实现总结:

项目中领导要求进行数据加密, 要求如下:

注意:加密后的字节码使用Base64转换成字符串
加密模式: CBC
填充模式: PKCS7Padding
加密密钥: 用户密钥的 SHA256 的32 bytes
AES IV : 加密密钥的前 16 bytes

//
//  NSString+Encrypt.h
//  SwiftTemplet
//
//  Created by Bin Shang on 2020/8/29.
//  Copyright © 2020 BN. All rights reserved.
//

#import <Foundation/Foundation.h>

NS_ASSUME_NONNULL_BEGIN

@interface NSString (Encrypt)

- (NSString *)SHA1;

- (NSString *)SHA256;

- (NSData *)SHA256Data;

///对明文加密
+(NSString *)encryptAESWithPlainText:(NSString *)plaintext;

///对密文解密
+(NSString *)decryptAESWithCipherText:(NSString *)ciphertexts;

    
@end

NS_ASSUME_NONNULL_END

//
//  NSString+Encrypt.m
//  SwiftTemplet
//
//  Created by Bin Shang on 2020/8/29.
//  Copyright © 2020 BN. All rights reserved.
//

#import "NSString+Encrypt.h"
#import <CommonCrypto/CommonCrypto.h>

@implementation NSString (Encrypt)

//
//  NSString+Encrypt.m
//  SwiftTemplet
//
//  Created by Bin Shang on 2020/8/29.
//  Copyright © 2020 BN. All rights reserved.
//

#import "NSString+Encrypt.h"
#import <CommonCrypto/CommonCrypto.h>

@implementation NSString (Encrypt)

- (NSString *)SHA1 {
    unsigned int outputLength = CC_SHA1_DIGEST_LENGTH;
    unsigned char output[outputLength];
    
    CC_SHA1(self.UTF8String, (unsigned int)[self lengthOfBytesUsingEncoding:NSUTF8StringEncoding], output);
    return [self toHexString:output length:outputLength];;
}

-(NSData *)SHA256Data{
    unsigned char hash[CC_SHA256_DIGEST_LENGTH];
    (void) CC_SHA256(self.UTF8String, (unsigned int)[self lengthOfBytesUsingEncoding:NSUTF8StringEncoding], hash);
    return ( [NSData dataWithBytes: hash length: CC_SHA256_DIGEST_LENGTH] );
}

- (NSString *)SHA256{
    unsigned int outputLength = CC_SHA256_DIGEST_LENGTH;
    unsigned char output[outputLength];
    
    CC_SHA256(self.UTF8String, (unsigned int)[self lengthOfBytesUsingEncoding:NSUTF8StringEncoding], output);
    return [self toHexString:output length:outputLength];;
}

- (NSString *)toHexString:(unsigned char*)data length:(unsigned int)length {
    NSMutableString *hash = [NSMutableString stringWithCapacity:length * 2];
    for (unsigned int i = 0; i < length; i++) {
        [hash appendFormat:@"%02x", data[i]];
        data[i] = 0;
    }
    return hash;
}

+(NSString *)encryptAESWithPlainText:(NSString *)plaintext{
    if (!plaintext) {
        return @"";
    }
    NSString *bundleIdentifier = [[NSBundle mainBundle] bundleIdentifier];
    NSString *sha1 = [bundleIdentifier SHA1];
    NSData *key = [sha1 SHA256Data];
    NSData * encryptData = [self AEC256EncryptWithPlainText:plaintext withKey:key];
    NSString *base64String = [encryptData base64EncodedStringWithOptions:NSDataBase64Encoding64CharacterLineLength];
    return base64String;
}

+(NSString *)decryptAESWithCipherText:(NSString *)ciphertexts{
    if (!ciphertexts) {
        return @"";
    }
    
    NSString *bundleIdentifier = [[NSBundle mainBundle] bundleIdentifier];
    NSString *sha1 = [bundleIdentifier SHA1];
    NSData *key = [sha1 SHA256Data];
    
    NSData *cipherData = [[NSData alloc]initWithBase64EncodedString:ciphertexts options:0];
    NSData *data = [self AES256DecryptWithCipherData:cipherData withKey:key];

    NSString *plainText = [[NSString alloc]initWithData:data encoding:NSUTF8StringEncoding];
    return plainText;
}
/*AES256加密方法*/
+(NSData *)AEC256EncryptWithPlainText:(NSString *)plainText withKey:(NSData *)key{
    if (plainText == nil) {
        return nil;
    }
    NSData *plainData = [plainText dataUsingEncoding:NSUTF8StringEncoding];
    
    char keyPtr[kCCKeySizeAES256+1];
    bzero(keyPtr, sizeof(keyPtr));

    NSUInteger dataLength = [plainData length];
    size_t bufferSize = dataLength + kCCBlockSizeAES128;
    void *buffer = malloc(bufferSize);
    bzero(buffer, sizeof(buffer));
    
    size_t numBytesEncrypted = 0;
    
    unsigned char *iv = malloc( 16 * sizeof(unsigned char) );
    [key getBytes:iv length:16];

    CCCryptorStatus cryptStatus = CCCrypt(kCCEncrypt,
                                          kCCAlgorithmAES,
                                          kCCOptionPKCS7Padding,
                                          [key bytes],
                                          [key length],
                                          iv /* initialization vector (optional) */,
                                          [plainData bytes], dataLength, /* input */
                                          buffer, bufferSize, /* output */
                                          &numBytesEncrypted);
    NSData *encryptData;
    if (cryptStatus == kCCSuccess) {
         encryptData = [NSData dataWithBytesNoCopy:buffer length:numBytesEncrypted];
    }
//     free the buffer;
//    free(buffer);
    free(iv);
    return encryptData;
}
/*AES256解密方法*/
+ (NSData *)AES256DecryptWithCipherData:(NSData *)cipherData withKey:(NSData *)key{
    if (!cipherData) {
        return nil;
    }
    // 'key' should be 32 bytes for AES256, will be null-padded otherwise
    char keyPtr[kCCKeySizeAES256+1]; // room for terminator (unused)
    bzero(keyPtr, sizeof(keyPtr)); // fill with zeroes (for padding)
    
    NSUInteger dataLength = [cipherData length];
    
    size_t bufferSize = dataLength + kCCBlockSizeAES128;
    void *buffer = malloc(bufferSize);
    
    unsigned char *iv = malloc( 16 * sizeof(unsigned char) );
    [key getBytes:iv length:16];
    
    size_t numBytesDecrypted = 0;
    CCCryptorStatus cryptStatus = CCCrypt(kCCDecrypt,
                                          kCCAlgorithmAES,
                                          kCCOptionPKCS7Padding,
                                          [key bytes],
                                          [key length],
                                          iv ,/* initialization vector (optional) */
                                          [cipherData bytes],
                                          dataLength, /* input */
                                          buffer, bufferSize, /* output */
                                          &numBytesDecrypted);
    NSData *encryptData;
    if (cryptStatus == kCCSuccess) {
         encryptData= [NSData dataWithBytesNoCopy:buffer length:numBytesDecrypted];
    }
//    free(buffer);
     //free the buffer;
    free(iv);
    return encryptData;
}


@end

🌰🌰:
let encryptText = NSString.encryptAES(withPlainText: "AABBCC测试数据")
let decryptText = NSString.decryptAES(withCipherText: encryptText)
 DDLog(decryptText)

2020-08-29 15:05:03.387 FirstViewController.swift.viewWillAppear(_:)[line 93]: AABBCC测试数据
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。