我正在将一段 PHP 代码重写为 C#。此代码用于密码散列。在第一步中,它生成一个像“password{salt}”这样的字符串,然后通过 sha512 哈希算法对其进行哈希处理。之后,循环再次对第一个散列和盐的组合进行散列 5000 次迭代。PHP 代码如下所示:<?php$password = 'abc';$salt = 'def';$salted = $password.'{'.$salt.'}';$digest = hash('sha512', $salted, true);for ($i=1; $i<5000; $i++) { $digest = hash('sha512', $digest.$salted, true);}$encodedPassword = base64_encode($digest);//$encodedPassword contains the final hash code我能够在没有循环的情况下让它工作(只有第一个 hash() 调用)。所以主散列和base64编码正确完成。我发现这部分是我无法用 C# 重写的:$digest.$salted$digest 似乎是一个二进制表示,因为 PHP 的 hash() 函数使用“true”作为最后一个参数(参见PHP hash - 手册)。$salted 是一个字符串。两者都被 PHP 的 dot / concat 运算符神奇地结合在一起。我想当使用带有非字符串操作数的点运算符时,会有某种从二进制到字符串的标准转换。到目前为止,这是我的代码:void Main(){ string password = "abc"; string salt = "def"; string salted = String.Format("{0}{{{1}}}", password, salt); byte[] digest = hash(salted); for(int i = 1; i < 1; i++) { digest = hash(String.Format("{0}{1}", System.Text.Encoding.UTF8.GetString(digest), salted)); } var encodedPassword = System.Convert.ToBase64String(digest); //$encodedPassword should contain the final hash code}static byte[] hash(string toHash) { System.Security.Cryptography.SHA512 sha512 = new System.Security.Cryptography.SHA512Managed(); return sha512.ComputeHash(System.Text.Encoding.UTF8.GetBytes(toHash));}如您所见,我尝试使用 System.Text.Encoding.UTF8.GetString() 将哈希字节转换回字符串,然后附加盐,但这不会产生与 PHP 代码相同的输出。如果有人可以帮助我,我会很高兴。非常感谢你。
1 回答
- 1 回答
- 0 关注
- 137 浏览
添加回答
举报
0/150
提交
取消