基本上我想编写计算sha1哈希的函数。在Objective-C和C#.NET中产生不同结果的SHA1哈希
到目前为止我试过的如下。
C#的.NET
byte[] p2 = System.Text.Encoding.Unicode.GetBytes("password");
System.Security.Cryptography.SHA1 sha = new System.Security.Cryptography.SHA1CryptoServiceProvider();
byte[] result = sha.ComputeHash(p2);
string encodedPassword = Convert.ToBase64String(result);
输出: 6Pl/upEE0epQR5SObftn + s2fW3M =
目标C
我已经加入类的Base64从NSData_Base64 Classes reference。
NSString *password = @"password";
NSData *data = [password dataUsingEncoding:NSUTF8StringEncoding];
NSString *unicodePassword = [[NSString alloc] initWithData:data encoding:NSUnicodeStringEncoding];
data = [unicodePassword dataUsingEncoding:NSUnicodeStringEncoding];
unsigned char hash[CC_SHA1_DIGEST_LENGTH];
CC_SHA1([data bytes], [data length], hash);
NSData *result = [NSData dataWithBytes:hash length:CC_SHA1_DIGEST_LENGTH];
NSLog(@"Result: %@",[result base64EncodedString]);
输出: dYusXVhObIBzJMgg1E1FJ9cK1NY =
任何人都可以请建议我究竟做错了什么?
为什么这两个值有所不同?
请纠正我的错误。
也许“NSData_Base64类参考”使用URL安全的base64,但C#.NET的System.Security.Cryptography.SHA1与URL不安全的一起工作?尝试使用联机SHA1加密器/解密器来比较结果。我建议使用可在此处找到的GData Base64:https://code.google.com/p/gdata-objectivec-client/。 –