在C#中,可以使用System.Security.Cryptography
命名空间下的类来实现哈希加密
using System;
using System.Security.Cryptography;
using System.Text;
class Program
{
static void Main()
{
string input = "Hello, World!"; // 要加密的字符串
// 使用SHA256哈希算法
using (SHA256 sha256 = SHA256.Create())
{
byte[] inputBytes = Encoding.UTF8.GetBytes(input);
byte[] hashBytes = sha256.ComputeHash(inputBytes);
StringBuilder sb = new StringBuilder();
for (int i = 0; i< hashBytes.Length; i++)
{
sb.Append(hashBytes[i].ToString("x2"));
}
Console.WriteLine("SHA256哈希值: " + sb.ToString());
}
// 使用MD5哈希算法
using (MD5 md5 = MD5.Create())
{
byte[] inputBytes = Encoding.UTF8.GetBytes(input);
byte[] hashBytes = md5.ComputeHash(inputBytes);
StringBuilder sb = new StringBuilder();
for (int i = 0; i< hashBytes.Length; i++)
{
sb.Append(hashBytes[i].ToString("x2"));
}
Console.WriteLine("MD5哈希值: " + sb.ToString());
}
}
}
这个示例首先创建了一个字符串input
,然后分别使用SHA256和MD5哈希算法对其进行加密。ComputeHash
方法接收一个字节数组作为输入,返回一个包含哈希值的字节数组。最后,将哈希值转换为16进制字符串并输出。
注意:哈希加密是不可逆的,因此无法从哈希值还原原始数据。它通常用于验证数据的完整性和安全存储密码等敏感信息。