我正在使用这个 Objective-C 类别来加密和解密我的字符串数据:https://gist.github.com/leeprobert/b83f07ca90ad657a1cd17f94b13138b1
我有一个像这样的 NSString 类别:
@implementation NSString (AESCrypt)
- (NSString *)AES128EncryptWithKeyNSString *)key
{
NSData *plainData = [self dataUsingEncoding:NSUTF8StringEncoding];
NSData *encryptedData = [plainData AES128EncryptedDataWithKey:key];
NSString *encryptedString = [encryptedData base64Encoding];
return encryptedString;
}
- (NSString *)AES128DecryptWithKeyNSString *)key
{
NSData *plainData = [self dataUsingEncoding:NSUTF8StringEncoding];
NSData *decryptedData = [plainData AES128DecryptedDataWithKey:key];
NSString *decryptedString = [[NSString alloc] initWithData:decryptedData encoding:NSUTF8StringEncoding];
return decryptedString;
}
@end
我的问题是,当我测试这个时,我得到了垃圾:
NSString* stringToEncrypt = @"Mary had a little lamb";
NSString* encryptedString = [stringToEncrypt AES128EncryptWithKey:eKey];
NSString* decryptedString = [encryptedString AES128DecryptWithKey:eKey];
NSLog(@"encryptedString = %@, decryptedString = %@", encryptedString, decryptedString);
这将记录为:
encryptedString = wLnJKED9oE4zC8dS9X7XskTs8kMTP59LUj8aatxW9+c=, decryptedString = (null)
我不相信我需要在加密过程中进行 base64 编码。这部分是别人的代码。我现在正在尝试解密。
Best Answer-推荐答案 strong>
您在解密过程中没有考虑 Base64 编码。而不是 [self dataUsingEncoding:NSUTF8StringEncoding] 你应该使用 [[NSData alloc] initWithBase64EncodedString:self options:0] 。
您是否要使用 Base64 仅取决于您在做什么。这是获取 NSData(即加密输出/解密输入)并将其转换为具有小字符集 (A-Za-z0-9+/= ) 的字符串的便捷方式。
关于ios - 我需要哪种编码来解密这个 AES128 数据,我们在Stack Overflow上找到一个类似的问题:
https://stackoverflow.com/questions/36774075/
|