iOS AES加密-无法加密
在我的项目中,我实现了AES 128 CBC加密。我使用的是类别,基于NSData。这是我的加密代码:iOS AES加密-无法加密,ios,encryption,cryptography,Ios,Encryption,Cryptography,在我的项目中,我实现了AES 128 CBC加密。我使用的是类别,基于NSData。这是我的加密代码: - (NSData*)AES128Decrypt { char ivPtr[kCCKeySizeAES128 + 1]; bzero(ivPtr, sizeof(ivPtr)); // fetch iv data [iv getCString:ivPtr maxLength:sizeof(ivPtr) encoding:NSUTF8StringEncoding
- (NSData*)AES128Decrypt
{
char ivPtr[kCCKeySizeAES128 + 1];
bzero(ivPtr, sizeof(ivPtr));
// fetch iv data
[iv getCString:ivPtr maxLength:sizeof(ivPtr) encoding:NSUTF8StringEncoding];
// 'key' should be 32 bytes for AES256, will be null-padded otherwise
char keyPtr[kCCKeySizeAES128 + 1]; // room for terminator (unused)
bzero(keyPtr, sizeof(keyPtr)); // fill with zeroes (for padding)
// fetch key data
[key getCString:keyPtr maxLength:sizeof(keyPtr) encoding:NSUTF8StringEncoding];
NSUInteger dataLength = [self length]; // dataLength = 19
//See the doc: For block ciphers, the output size will always be less than or
//equal to the input size plus the size of one block.
//That's why we need to add the size of one block here
size_t bufferSize = dataLength + kCCBlockSizeAES128;
void* buffer = malloc(bufferSize);
size_t numBytesDecrypted = 0;
CCCryptorStatus cryptStatus = CCCrypt(kCCDecrypt, kCCAlgorithmAES128, 0,
keyPtr, kCCKeySizeAES128,
ivPtr,
[self bytes], dataLength,
buffer, bufferSize,
&numBytesDecrypted); // buffer = 0 & numBytesDecrypted = 0
if (cryptStatus == kCCSuccess)
{
//the returned NSData takes ownership of the buffer and will free it on deallocation
return [NSData dataWithBytes:buffer length:numBytesDecrypted] ; // returns 0
}
free(buffer); //free the buffer;
return nil;
}
这就是我在view类中对它的称呼:
- (void) testActuallyEncrypting :(NSString*) hexString {
NSLog(@"String to Encrypt : %@", hexString); // prints test12
@try {
//Convert NSString to NSData
NSData *data = [self dataFromHexString:hexString]; // [hexString dataUsingEncoding:NSUTF8StringEncoding]; //
// // Prepare the NSDAta obj to store the encrypted pswd
NSData *encryptedData = [NSData dataWithBytes:[data bytes] length:[data length]]; // 6bytes
NSData *decryptedData = [encryptedData AES128Decrypt]; // 0bytes
NSString *decryptedString = [NSString stringWithUTF8String:[decryptedData bytes]]; // NULL Exception
NSLog(@"Decrypted String : %@", decryptedString);
decryptedString = [self addPaddingToString:decryptedString];
decryptedData = [NSData dataWithBytes:[decryptedString UTF8String] length:[[decryptedString dataUsingEncoding:NSUTF8StringEncoding] length]];
encryptedData = [decryptedData AES128Encrypt];
if (encryptedData!=nil)
{
NSString *encryptedHexString = [self hexStringFromData:encryptedData];
NSLog(@"Encrypted HexString : %@",encryptedHexString);
}
}@catch (NSException *ex) {
NSLog(@"Exception : %@", ex);
}
}
我正在传递要加密的“test12”
字符串。调用AES128Decrypt
,decryptedData
为0,因此下一行decryptedString
抛出空异常-异常:**+[NSString stringWithUTF8String:::]:Null cString
有人能帮我知道为什么解密的数据是空的吗。我的解密方法哪里出了问题
请帮帮我。过去两天来我一直在做这件事。在互联网上搜索了很多,但找不到任何解决方案。
非常感谢您的帮助。谢谢
更新:-
在我的类中添加了@Zaph的方法,我正在调用它
NSLog(@"String to Encrypt : %@", hexString);
NSString *iv = @"fedcba9876543210";
NSString *key = @"0123456789abcdef";
// Convert str to encrypt, iv & key from NSString to NSData
NSData *dataIn = [hexString dataUsingEncoding:NSUTF8StringEncoding];
NSData *ivData = [iv dataUsingEncoding:NSUTF8StringEncoding];
NSData *symKey = [key dataUsingEncoding:NSUTF8StringEncoding];
NSError *error;
NSData *result = [LoginViewController doCipher:dataIn iv:ivData key:symKey context:kCCEncrypt error:&error]; // result = 16bytes
if (result != nil) {
// Convert result to satring
NSString *resultStr = [[NSString alloc] initWithData:result encoding:NSUTF8StringEncoding];
NSLog(@"Encrypted Str = %@", resultStr ); // Encrypted Str = (null) ????
为什么转换的字符串为空?请帮忙。谢谢没有必要让加密变得如此复杂,这里有一个基本的加密/解密方法。iv和钥匙的长度必须正确。值上下文为
kCCEncrypt
或kCCDecrypt
+ (NSData *)doCipher:(NSData *)dataIn
iv:(NSData *)iv
key:(NSData *)symmetricKey
context:(CCOperation)encryptOrDecrypt
error:(NSError **)error
{
CCCryptorStatus ccStatus = kCCSuccess;
size_t cryptBytes = 0;
NSMutableData *dataOut = [NSMutableData dataWithLength:dataIn.length + kCCBlockSizeAES128];
ccStatus = CCCrypt( encryptOrDecrypt,
kCCAlgorithmAES128,
kCCOptionPKCS7Padding,
symmetricKey.bytes,
kCCKeySizeAES128,
iv.bytes,
dataIn.bytes,
dataIn.length,
dataOut.mutableBytes,
dataOut.length,
&cryptBytes);
if (ccStatus == kCCSuccess) {
dataOut.length = cryptBytes;
}
else {
if (error) {
*error = [NSError errorWithDomain:@"kEncryptionError"
code:ccStatus
userInfo:nil];
}
dataOut = nil;
}
return dataOut;
}
不要使用
@try
和@catch
来捕捉编程错误。在Objective-C中,它们不是控制结构。我发现使用NSUTF8StringEncoding将NSData转换为NSString编码返回null。我尝试使用NSASCIIStringEncoding,它返回值。但是字符串值和数据值是不同的。它们应该是相同的nah?并非所有数据都是有效的UTR-8。对于数据的字符串表示,常用的约定是使用Base64编码。而不是NSString*resultStr=[[NSString alloc]initWithData:result encoding:NSUTF8StringEncoding]代码>使用base64编码:NSString*resultBase64Str=[result base64EncodedStringWithOptions:0]
如果使用NSASCIIStringEncoding
您将获得不可显示的字符,可能不是您想要的。感谢您提供上述代码。我在viewController类中添加了它。以NSData形式传递iv、key、str(iv和key为16字节),并调用方法-NSData*result=[LoginViewController doCipher:dataIn iv:ivData key:symKey上下文:KCCEnConcrypt error:&error];但当我将其转换为NSString时,得到的结果是16字节。你能检查一下上面的代码吗?已经在更新中添加了这个。错误也是零-因此没有错误。为什么字符串为空?你们能帮我找一下吗?得到结果后,我把它转换成字符串(它只能通过NSASCIIStringEncoding工作。然后我尝试将字符串转换回nsdata。我得到了其中3个的不同值。它们3不应该是相同的,或者至少是两个nsdata。毫无疑问,在解密结果并转换为字符串时,我得到了传递的原始字符串,它正在工作。但我想知道这一点,以获取知识,我很好奇。)要知道同样的道理。谢谢。在您的代码中,您使用了kCCOptionPKCS7Padding,我认为这将用于PKCS实现。我使用了CBC。CBC有任何特殊设置/参数值吗?kCCOptionPKCS7Padding
选项用于AES。如果输入的清除数据的长度不是块大小的精确倍数,则需要此选项。Not所有数据都是有效的UTF-8字符串。通常的解决方案是使用base64编码,即将加密的数据转换为base64字符串。上面的代码为数据提供加密/解密,特别是NSData
,这就是加密的作用,即数据加密。如果需要某种其他格式,则需要在加密前后进行加密加密/解密,即格式转换。