第一次遇到需要MD5加密的,记录下学习的结果。
MD5 ,对一个给定的目标字符串,进行计算他的 hash 值,就是 MD5 的过程。
MD5(目标):出来的是 32位加密后的 16进制的字符串。
16位 的 MD5加密,实际上就是 进行了 32 位的加密后,截取了 中间 16位的内容。
有的说 MD5 ,64 位加密??? 实际,32 位加密后,转化为了 base 64。
涉及的代码编写记录:【VS2022 的控制台 Program.cs ,我凑,居然 Main 方法都没了。第一次建立,没适应。不过,应该能看懂】
using System.Security.Cryptography; // MD5 加密类的
using System.Text; // Encoding 的
string inputStr = "1631154285196123";
string outputStr = "4c12fabe710c6abe795d0cbe119dba8c";
Console.WriteLine($"需要加密的内容: {inputStr}");
Console.WriteLine($"期望的结果: {outputStr}");
Console.WriteLine();
MD5Encrypt16(inputStr);
Console.WriteLine();
MD5Encrypt32(inputStr);
Console.WriteLine();
MD5Encrypt64(inputStr);
Console.WriteLine();
MD5Encrypt32Using(inputStr);
// 法 1 16 位?MD5 加密。 字母是大写 。 16 位 加密????? 实际 还是 32 位的,截取了 中间的一部分????
// 16 位加密 就是从 32位 MD5散列中 把 中间16位 提取出来!
static void MD5Encrypt16(string inputStr) {
MD5 md5 = MD5.Create();
string t = BitConverter.ToString(md5.ComputeHash(Encoding.Default.GetBytes(inputStr)), 4, 8);
t = t.Replace("-",string.Empty); // 上面转化为 string 的方法,默认用了 - 拼接,所以要去除。
Console.WriteLine($"法 1 加密的结果 : {t}");
Console.WriteLine($"法 1 加密->小写 :{t.ToLower()}");
md5.Dispose(); // 最好记得释放资源。
}
// 法 2 32 位?MD5 加密。
static void MD5Encrypt32(string inputStr) {
string outStr1 = string.Empty;
string outStr2 = string.Empty;
// 1: 实例化一个 MD5 对象 md5
MD5 md5 = MD5.Create();
// 2:将加密对象 转化为 byte[] 数组。 (字节数组) 加密后 是一个 字节数组(1 byte 字节 = 8 bit 位 ,char 是字符 = 2 字节。1 汉字 一般是 2 字节)。 注意编码 utf8 ,unicode 等的选择
byte[] byteStr = md5.ComputeHash(Encoding.UTF8.GetBytes(inputStr));
// 3:通过循环,将 字节 类型的数组,-》字符串, 此字符串是常规 字符 格式化 所得。
foreach (var item in byteStr) {
// 将得到的 字符数组元素 使用 16 进制类型格式化,拼接
outStr1 = string.Concat(outStr1, item.ToString("x2")); // x 格式化后的字符是 小写
outStr2 = string.Concat(outStr2, item.ToString("X2")); // X 格式化后的字符是 大写
}
Console.WriteLine($"法 2 加密的结果1: {outStr1}");
Console.WriteLine($"法 2 加密的结果2: {outStr2}");
md5.Dispose(); // 最好记得释放资源。
}
// 法 3 64 位?MD5 加密。
static void MD5Encrypt64(string inputStr)
{
MD5 md5 = MD5.Create();
byte[] outStr = md5.ComputeHash(Encoding.UTF8.GetBytes(inputStr));
var res = Convert.ToBase64String(outStr);
Console.WriteLine($"法 3 加密后转为位 64 位 字符串结果:{res}");
md5.Dispose(); // 最好记得释放资源。
}
// 法 2 Using 写法, + 使用 BitConver 转化
static void MD5Encrypt32Using(string inputStr) {
using (MD5 md5 = MD5.Create()) { // 或者 C# 8 语法, 不用写 (){}
// 目的,不用手动去 释放 MD5 资源了。 就不用 手动 md5.Dispose();
string outStr = BitConverter.ToString(md5.ComputeHash(Encoding.Default.GetBytes(inputStr)));
outStr = outStr.Replace("-",string.Empty);
Console.WriteLine($"法 2 using + BitConverter 转化,32 位加密结果: {outStr}");
}
}