ios 16进制加密 AES 128 ECB PKCS7Padding

1.使用

 NSString *originalStr=@"AES";  
  
    //加密  
    NSString *encryStr = [AES128Util AES128Encrypt:originalStr key:AES_KEY];  
    //解密  
    NSString *decryStr = [AES128Util AES128Decrypt:encryStr key:AES_KEY];  
      
    NSLog(@"\n加密前:%@\n加密后:%@ \n解密后:%@",originalStr,encryStr,decryStr);

2.具体实现类  .h文件

#import <Foundation/Foundation.h>  
  
@interface AES128Util : NSObject  
  
+(NSString *)AES128Encrypt:(NSString *)plainText key:(NSString *)key;  
  
+(NSString *)AES128Decrypt:(NSString *)encryptText key:(NSString *)key;  
  
@end  

.m 文件

#import "AES128Util.h"  
#import <CommonCrypto/CommonCryptor.h>  
#import "GTMBase64.h"  
  
@implementation AES128Util  
  
+(NSString *)AES128Encrypt:(NSString *)plainText key:(NSString *)key  
{  
    char keyPtr[kCCKeySizeAES128+1];  
    memset(keyPtr, 0, sizeof(keyPtr));  
    [key getCString:keyPtr maxLength:sizeof(keyPtr) encoding:NSUTF8StringEncoding];  
      
    NSData* data = [plainText dataUsingEncoding:NSUTF8StringEncoding];  
    NSUInteger dataLength = [data length];  
      
    size_t bufferSize = dataLength + kCCBlockSizeAES128;  
    voidvoid *buffer = malloc(bufferSize);  
    size_t numBytesEncrypted = 0;  
    CCCryptorStatus cryptStatus = CCCrypt(kCCEncrypt,  
                                          kCCAlgorithmAES128,  
                                          kCCOptionPKCS7Padding|kCCOptionECBMode,  
                                          keyPtr,  
                                          kCCBlockSizeAES128,  
                                          NULL,  
                                          [data bytes],  
                                          dataLength,  
                                          buffer,  
                                          bufferSize,  
                                          &numBytesEncrypted);  
    if (cryptStatus == kCCSuccess) {  
        NSData *resultData = [NSData dataWithBytesNoCopy:buffer length:numBytesEncrypted];  
        //return [GTMBase64 stringByEncodingData:resultData];  
        return [self hexStringFromData:resultData];  
  
    }  
    free(buffer);  
    return nil;  
}  
  
  
+(NSString *)AES128Decrypt:(NSString *)encryptText key:(NSString *)key  
{  
    char keyPtr[kCCKeySizeAES128 + 1];  
    memset(keyPtr, 0, sizeof(keyPtr));  
    [key getCString:keyPtr maxLength:sizeof(keyPtr) encoding:NSUTF8StringEncoding];  
      
    //NSData *data = [GTMBase64 decodeData:[encryptText dataUsingEncoding:NSUTF8StringEncoding]];  
      
    NSData *data=[self dataForHexString:encryptText];  
      
    NSUInteger dataLength = [data length];  
    size_t bufferSize = dataLength + kCCBlockSizeAES128;  
    voidvoid *buffer = malloc(bufferSize);  
      
    size_t numBytesCrypted = 0;  
    CCCryptorStatus cryptStatus = CCCrypt(kCCDecrypt,  
                                          kCCAlgorithmAES128,  
                                          kCCOptionPKCS7Padding|kCCOptionECBMode,  
                                          keyPtr,  
                                          kCCBlockSizeAES128,  
                                          NULL,  
                                          [data bytes],  
                                          dataLength,  
                                          buffer,  
                                          bufferSize,  
                                          &numBytesCrypted);  
    if (cryptStatus == kCCSuccess) {  
        NSData *resultData = [NSData dataWithBytesNoCopy:buffer length:numBytesCrypted];  
        return [[[NSString alloc] initWithData:resultData encoding:NSUTF8StringEncoding] autorelease];  
    }  
    free(buffer);  
    return nil;  
}  
  
// 普通字符串转换为十六进  
+ (NSString *)hexStringFromData:(NSData *)data {  
    Byte *bytes = (Byte *)[data bytes];  
    // 下面是Byte 转换为16进制。  
    NSString *hexStr = @"";  
    for(int i=0; i<[data length]; i++) {  
        NSString *newHexStr = [NSString stringWithFormat:@"%x",bytes[i] & 0xff]; //16进制数  
        newHexStr = [newHexStr uppercaseString];  
          
        if([newHexStr length] == 1) {  
            newHexStr = [NSString stringWithFormat:@"0%@",newHexStr];  
        }  
          
        hexStr = [hexStr stringByAppendingString:newHexStr];  
          
    }  
    return hexStr;  
}  
  
//参考:http://blog.csdn.net/linux_zkf/article/details/17124577  
//十六进制转Data  
+ (NSData*)dataForHexString:(NSString*)hexString  
{  
    if (hexString == nil) {  
          
        return nil;  
    }  
      
    const char* ch = [[hexString lowercaseString] cStringUsingEncoding:NSUTF8StringEncoding];  
    NSMutableData* data = [NSMutableData data];  
    while (*ch) {  
        if (*ch == ' ') {  
            continue;  
        }  
        char byte = 0;  
        if ('0' <= *ch && *ch <= '9') {  
              
            byte = *ch - '0';  
        }else if ('a' <= *ch && *ch <= 'f') {  
              
            byte = *ch - 'a' + 10;  
        }else if ('A' <= *ch && *ch <= 'F') {  
              
            byte = *ch - 'A' + 10;  
              
        }  
          
        ch++;  
          
        byte = byte << 4;  
          
        if (*ch) {  
              
            if ('0' <= *ch && *ch <= '9') {  
                  
                byte += *ch - '0';  
                  
            } else if ('a' <= *ch && *ch <= 'f') {  
                  
                byte += *ch - 'a' + 10;  
                  
            }else if('A' <= *ch && *ch <= 'F'){  
                  
                byte += *ch - 'A' + 10;  
                  
            }  
              
            ch++;  
              
        }  
          
        [data appendBytes:&byte length:1];  
          
    }  
      
    return data;  
}  


  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
AES128 ECB PKCS5Padding算法是一种对称加密算法,具有较快的加密速度和较高的安全性。 在C代码中实现上述算法,我们需要使用相关的库函数。以OpenSSL为例,在C语言中可以使用OpenSSL提供的APIAES128 ECB PKCS5Padding的加解密操作。 下面是一个简单的示例代码: ```c #include <stdio.h> #include <openssl/aes.h> int main() { // 原始数据 unsigned char plaintext[17] = "Hello, world!"; unsigned char ciphertext[16]; unsigned char recoveredtext[16]; // 密钥 unsigned char aes_key[16] = "1234567890123456"; AES_KEY key; // 设置加密密钥 if (AES_set_encrypt_key(aes_key, 128, &key) < 0) { printf("Error setting encryption key.\n"); return -1; } // 加密 AES_encrypt(plaintext, ciphertext, &key); // 解密 if (AES_set_decrypt_key(aes_key, 128, &key) < 0) { printf("Error setting decryption key.\n"); return -1; } AES_decrypt(ciphertext, recoveredtext, &key); printf("Plaintext: %s\n", plaintext); printf("Ciphertext: "); for (int i = 0; i < 16; i++) { printf("%02x ", ciphertext[i]); } printf("\n"); printf("Recovered text: %s\n", recoveredtext); return 0; } ``` 上述代码中,我们首先定义了原始数据(明文)`plaintext`,密钥`aes_key`以及存储加密后数据(密文)`ciphertext`和解密后数据(恢复文本)`recoveredtext`的数组。然后,使用`AES_set_encrypt_key`函数设置加密密钥,并调用`AES_encrypt`函数加密操作。再使用`AES_set_decrypt_key`函数设置解密密钥,并调用`AES_decrypt`函数行解密操作。最后,打印输出明文、密文和恢复文本。 需要注意的是,ECB模式不适合处理大量数据加密,因为它没有使用初始化向量,相同的明文将会得到相同的密文,存在安全性隐患。而且ECB模式也没有提供数据完整性验证,因此在实际应用中,建议使用更为安全的加密模式。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值