4

我在我的 c++ 代码中使用了 Sha256 类的更新函数将几个字符串包含到一个哈希值中,但是我在 .net 类 Sha256 中找不到这个函数。这个功能是在C++实现,Java实现Sha,而不是.net?

C++ 中的示例代码:

l_ceSHA2.Init();
for ( l_dwordCnt = 0; l_dwordCnt < l_dwordHashRounds; l_dwordCnt++)
{
    l_ceSHA2.Update( mp_strPassword, strlen( mp_strPassword )));
    l_ceSHA2.Update( mp_byteSalt, 32 );
}
l_ceSHA2.Final( mp_byteCryptoKey);

所以,它就像 PBKDF,但更简单。

C中的Sha256代码供参考

4

1 回答 1

5

您可以使用TransformBlock. 这是一个示例,说明如何:

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

// Example code for using TransformBlock to hash data in chunks

namespace HashTest
{
    class HashTest
    {
        static void Main(string[] args)
        {
            SHA256 hash = SHA256.Create();
            ASCIIEncoding encoding = new ASCIIEncoding();
            string password = "password";

            // Hash a string using ComputeHash
            string sourcetext = password;
            Console.WriteLine(sourcetext);
            byte[] sourcebytes = encoding.GetBytes(sourcetext);
            byte[] hashBytes = hash.ComputeHash(sourcebytes);
            string hashStr = BitConverter.ToString(hashBytes).Replace("-", "");
            Console.WriteLine(hashStr);

            // Hash exactly two copies of a string
            // (used to cross verify other methods below).
            Console.WriteLine();
            sourcetext = password + password;
            Console.WriteLine(sourcetext);
            sourcebytes = encoding.GetBytes(sourcetext);
            hashBytes = hash.ComputeHash(sourcebytes);
            hashStr = BitConverter.ToString(hashBytes).Replace("-", "");
            Console.WriteLine(hashStr);

            // Hash a string using TransformFinalBlock
            Console.WriteLine();
            sourcetext = password;
            sourcebytes = encoding.GetBytes(sourcetext);
            Console.WriteLine(sourcetext);
            hash.TransformFinalBlock(sourcebytes, 0, sourcebytes.Length);
            hashBytes = hash.Hash;
            hashStr = BitConverter.ToString(hashBytes).Replace("-", "");
            Console.WriteLine(hashStr);

            // At this point we've finalized the hash. To
            // reuse it we must first call Initialize().

            // Hash string twice using TransformBlock / TransformFinalBlock
            Console.WriteLine();
            hash.Initialize();
            sourcetext = password;
            sourcebytes = encoding.GetBytes(sourcetext);
            Console.Write(sourcetext);
            hash.TransformBlock(sourcebytes, 0, sourcebytes.Length, null, 0);
            Console.WriteLine(sourcetext);
            hash.TransformFinalBlock(sourcebytes, 0, sourcebytes.Length);
            hashBytes = hash.Hash;
            hashStr = BitConverter.ToString(hashBytes).Replace("-", "");
            Console.WriteLine(hashStr);

            // Hash string twice using TransformBlock in a loop

            Console.WriteLine();
            hash.Initialize();
            sourcetext = password;
            sourcebytes = encoding.GetBytes(sourcetext);
            for (int i = 0; i < 2; ++i)
            {
                Console.Write(sourcetext);
                hash.TransformBlock(sourcebytes, 0, sourcebytes.Length, null, 0);
            }
            Console.WriteLine();
            hash.TransformFinalBlock(sourcebytes, 0, 0);
            hashBytes = hash.Hash;
            hashStr = BitConverter.ToString(hashBytes).Replace("-", "");
            Console.WriteLine(hashStr);
        }
    }
}
于 2013-02-13T22:39:12.127 回答