using System.Security.Cryptography;
public static void Main()
string source = "Hello World!";
using (SHA256 sha256Hash = SHA256.Create())
string hash = GetHash(sha256Hash, source);
Console.WriteLine("The SHA256 hash of" + source + " is: " + hash + ".");
Console.WriteLine("Verifying the hash...");
if (VerifyHash(sha256Hash, source, hash))
Console.WriteLine("The hashes are the same.");
Console.WriteLine("The hashes are not same.");
private static string GetHash(HashAlgorithm hashAlgorithm, string input)
byte[] data = hashAlgorithm.ComputeHash(Encoding.UTF8.GetBytes(input));
var sBuilder = new StringBuilder();
for (int i = 0; i < data.Length; i++)
sBuilder.Append(data[i].ToString("x2"));
return sBuilder.ToString();
private static bool VerifyHash(HashAlgorithm hashAlgorithm, string input, string hash)
var hashOfInput = GetHash(hashAlgorithm, input);
StringComparer comparer = StringComparer.OrdinalIgnoreCase;
return comparer.Compare(hashOfInput, hash) == 0;