在C#中从十六进制/二进制字符串计算SHA1

时间:2013-09-16 13:05:40

标签: c# hex sha1

经过24小时的编程后,我终于破解了,我想创建一个C#WindowsForm应用程序,它向你显示散列六字符串输入的值,就像在hashcalc中一样。 即使在谷歌搜索之后我也只能用于文本字符串输入。 为了演示,输入060201080808040602040909080909003583150369840500应该输出d8f6b336a4df3336bf7de58a38b1189f6c5ce1e8 而不是a6879cb4510b18e8f41b3491ce474fd2ff9e2979 这也适用于SHA1 Hashing,所以只保留它,谢谢!

4 个答案:

答案 0 :(得分:1)

对于此090505050509050009080003000605003569190380108300 我有3b8d562adb792985a7393a6ab228aa6e7526410a,而不是3b8d562adb792985a7393a6ab228aa6e752641a

我认为最后一个字节是错误的。

答案 1 :(得分:0)

我想我真的不明白你的问题。您可以散列任何输入并以任何方式输出它。为此,您可以使用您选择的编码的Encoding类并调用GetBytes()方法。然后你拿SHA1类让它计算哈希值。对于用户文本,您告诉字符串类使用十六进制格式化数字。这不仅适用于SHA1类;)

答案 2 :(得分:0)

您需要导入命名空间:

using System.Security.Cryptography

并致电

var hash = new SHA1CryptoServiceProvider().ComputeHash(inputBytes);

生成哈希。

如果你的问题是将十六进制字符串转换为字节,这里有一个完整的示例,展示了如何解析输入并格式化输出:

var input = "060201080808040602040909080909003583150369840500";

// parse the input into a byte[]
var inputBytes = Enumerable.Range(0, input.Length/2)
                           .Select(i => input.Substring(i*2, 2))
                           .Select(s => byte.Parse(s, NumberStyles.HexNumber))
                           .ToArray();

var hash = new SHA1CryptoServiceProvider().ComputeHash(inputBytes);

var outputHexString = string.Join(" ", 
    hash.Select(b => b.ToString("X")).ToArray());

Console.WriteLine(outputHexString);

以下是它的工作原理:http://ideone.com/BE7ecU

答案 3 :(得分:0)

private void button1_Click(object sender, EventArgs e)
{
    string input= "060201080808040602040909080909003583150369840500";
    SHA1CryptoServiceProvider sha1 = new SHA1CryptoServiceProvider();
    byte[] hash = sha1.ComputeHash(ConvertHexStringToByteArray(input));
    string delimitedHexHash = BitConverter.ToString(hash);
    string hexHash = delimitedHexHash.Replace("-", "");

    MessageBox.Show(hexHash); 
}

public static byte[] ConvertHexStringToByteArray(string hexString)
{
    if (hexString.Length % 2 != 0)
    {
        throw new ArgumentException(String.Format(CultureInfo.InvariantCulture, "The binary key cannot have an odd number of digits: {0}", hexString));
    }

    byte[] HexAsBytes = new byte[hexString.Length / 2];
    for (int index = 0; index < HexAsBytes.Length; index++)
    {
        string byteValue = hexString.Substring(index * 2, 2);
        HexAsBytes[index] = byte.Parse(byteValue, NumberStyles.HexNumber, CultureInfo.InvariantCulture);
    }

    return HexAsBytes;
}