比特币sha256到hex会产生与预期不同的结果

时间:2017-04-13 06:33:11

标签: c# arrays string sha256 bitcoin

我正在尝试按照有关从 - https://en.bitcoin.it/wiki/Wallet_import_format获取Hex比特币私钥的WIF的说明进行操作 但是,当我尝试散列字符串(包括0x80字节)时,我得到的结果与预期的不同。 我应该得到8147786C4D15106333BF278D71DADAF1079EF2D2440A4DDE37D747DED5403592。 相反,我收到了e2e4146a36e9c455cf95a4f259f162c353cd419cc3fd0e69ae36d7d1b6cd2c09。

我在谷歌上广泛阅读,我明白我应该将字符串转换为二进制文件。我做了,然后将这些二进制文件中的char数组散列到相同的结果。

感谢@Heinan Cabouly和@JaredPar

以下是工作代码:

using System;
using System.Security.Cryptography;
using System.Text;
using System.Linq;

namespace Base58Encode
{

    internal class Program
    {
        public static string Str = "800C28FCA386C7A227600B2FE50B7CAE11EC86D3BF1FBE471BE89827E19D72AA1D";
        public static byte[] Bytes;
        public static void Main()
        {
            Bytes = StringToByteArray(Str);
            SHA256Managed sha = new SHA256Managed();
            string hashstr = String.Empty;
            byte[] encrypt = sha.ComputeHash(Bytes);
            foreach (byte b in encrypt)
            {
                hashstr += b.ToString("x2");
            }
            Console.WriteLine(hashstr);
            //prints e2e4146a36e9c455cf95a4f259f162c353cd419cc3fd0e69ae36d7d1b6cd2c09
            //instead of 8147786C4D15106333BF278D71DADAF1079EF2D2440A4DDE37D747DED5403592
            Console.ReadLine();

        }
        public static byte[] StringToByteArray(string hex)
        {
            return Enumerable.Range(0, hex.Length)
                         .Where(x => x % 2 == 0)
                         .Select(x => Convert.ToByte(hex.Substring(x, 2), 16))
                         .ToArray();

        }
    }
}

这是如何在C#中散列十六进制字符串SHA-256。 谢谢大家!帮了我很多忙!

1 个答案:

答案 0 :(得分:2)

如前所述,您用于转换的方法并不合适。您可以使用此方法(取自@JaredPar的stackoverflow):

public static byte[] StringToByteArray(string hex) {
    return Enumerable.Range(0, hex.Length)
                 .Where(x => x % 2 == 0)
                 .Select(x => Convert.ToByte(hex.Substring(x, 2), 16))
                 .ToArray();
}

用str(表示HEX字符串)调用此函数,它将返回HEX表示。

从那里,你可以按照书面继续你的功能。