我正在使用以下代码作为示例。如果我错了,请帮帮我。
- (void)storeToKeychain {
kPassword = [self computeSHA256DigestForString:[NSString stringWithFormat:@"%@%i%@", [username stringByAddingPercentEscapesUsingEncoding:NSUTF8StringEncoding], pinHash, SALT_HASH];
NSData *data = [@"Data" dataUsingEncoding:NSUTF8StringEncoding];
NSError *error;
NSData *encryptedData = [RNEncryptor encryptData:data
withSettings:kRNCryptorAES256Settings
password:kPassword
error:&error];
}
- (NSString*)computeSHA256DigestForString:(NSString*)input {
const char *cstr = [input cStringUsingEncoding:NSUTF8StringEncoding];
NSData *data = [NSData dataWithBytes:cstr length:input.length];
uint8_t digest[CC_SHA256_DIGEST_LENGTH];
// This is an iOS5-specific method.
// It takes in the data, how much data, and then output format, which in this case is an int array.
CC_SHA256(data.bytes, data.length, digest);
// Setup our Objective-C output.
NSMutableString* output = [NSMutableString stringWithCapacity:CC_SHA256_DIGEST_LENGTH * 2];
// Parse through the CC_SHA256 results (stored inside of digest[]).
for(int i = 0; i < CC_SHA256_DIGEST_LENGTH; i++) {
[output appendFormat:@"%02x", digest[i]];
}
return output;
}
我的应用程序有一个设置和登录页面。每当用户创建帐户时,我希望将密码存储在密钥链中进行加密,为了增加安全性,我可能应该使用用户名。因此,当用户创建帐户时,我想使用RNCryptor来加密用户在密钥链中的用户名和密码。
我不确定在RNEcryptor方法中为kPassword
使用什么密码。我最初考虑使用由UUID, username and a random 40 character salt hash
组成的SHA256散列将密码加密到密钥链中。后来我找到了RNCryptor,我想知道是否可以使用SHA256 hash
作为kPassword
,或者是否有其他选择?
发布于 2015-02-04 14:14:49
尝尝这个
从https://github.com/Gurpartap/AESCrypt-ObjC添加AESCrypt-ObjC-master
现在将这些添加到顶部
#import "AESCrypt.h"
然后添加这些
NSString *message = @"yourStringtobeencrypted";
NSString *password = @"yourpassword";
NSString *encryptedData = [AESCrypt encrypt:message password:password];
这就对了..用于解密
NSString *message1 = [AESCrypt decrypt:encryptedData password:password];
:-)
https://stackoverflow.com/questions/22125118
复制相似问题