有没有办法在 Cocoa Touch 中获得实际的 PKCS5 填充?虽然我很清楚出于解密目的,PKCS7 和 PKCS5 是兼容的,但我需要匹配服务器使用的确切加密方法,因为加密的密码经过哈希处理并用作加密数据的解密密钥。这很复杂,但很安全。不幸的是,如果您之后对填充字符串进行散列处理,我认为 PKCS7 和 PKCS5 不能互换使用。谁能帮我?如果它与 NSData+CommonCrypto 或 RNCryptor 库配合得很好,则可以加分。
问问题
1982 次
1 回答
4
这是我的解决方案。像魅力一样工作。
NSString *password = @"YOUR PASSWORD HERE";
NSMutableData *passwordData = [[NSMutableData alloc] initWithData:[password dataUsingEncoding:NSUTF8StringEncoding]];
int blockSize = 16;
int charDiv = blockSize - ((passwordData.length + 1) % blockSize);
//PKCS5 Padding
NSMutableString *padding = [[NSMutableString alloc] initWithFormat:@"%c",(unichar)10];
for (int c = 0; c <charDiv; c++) {
[padding appendFormat:@"%c",(unichar)charDiv];
}
[passwordData appendData:[padding dataUsingEncoding:NSUTF8StringEncoding]];
...您的填充数据将在密码数据中。
于 2013-02-27T18:17:18.363 回答