【发布时间】:2016-04-21 15:25:51
【问题描述】:
我正在使用这个 Objective-C 类别来加密和解密我的字符串数据:https://gist.github.com/leeprobert/b83f07ca90ad657a1cd17f94b13138b1
我有一个像这样的 NSString 类别:
@implementation NSString (AESCrypt)
- (NSString *)AES128EncryptWithKey:(NSString *)key
{
NSData *plainData = [self dataUsingEncoding:NSUTF8StringEncoding];
NSData *encryptedData = [plainData AES128EncryptedDataWithKey:key];
NSString *encryptedString = [encryptedData base64Encoding];
return encryptedString;
}
- (NSString *)AES128DecryptWithKey:(NSString *)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 编码。这部分是别人的代码。我现在正在尝试解密。
【问题讨论】:
标签: ios objective-c nsstring aes nsdata