C#使用MD5算法对密码进行加密的示例代码

 更新时间:2024年03月21日 11:28:06   作者:wenchm  
MD5(Message Digest Algorithm 5)是一种被广泛使用的“消息-摘要算法”,“消息-摘要算法”实际上就是一个单项散列函数,数据块经过单向散列函数得到一个固定长度的散列值,本文给大家介绍了C#使用MD5算法对密码进行加密,需要的朋友可以参考下

一、涉及到的知识点

1.MD5

MD5(Message Digest Algorithm 5)是一种被广泛使用的“消息-摘要算法”。“消息-摘要算法”实际上就是一个单项散列函数,数据块经过单向散列函数得到一个固定长度的散列值,数据块的签名就是计算数据块的散列值,MD5算法的散列值为128位。

2.使用基类的 Create 方法来创建 MD5 对象

应该使用其基类的 Create 方法来创建 MD5 对象。如果还是用MD5CryptoServiceProvider 类,那么将会得到警告SYSLIB0021。

使用 MD5.Create() 方法来创建 MD5 对象更加简洁易读。这种方法也适用于其他过时的加密类,如 SHA1CryptoServiceProvider、SHA256CryptoServiceProvider 等。通过使用基类的 Create() 方法,代码将更加简洁、易读且符合最佳实践。

using System.Security.Cryptography;
 
// ...
 
MD5 md5 = MD5.Create();

3.对每个字节进行加密并将其转换为十六进制字符串

str += md5data[i].ToString("x").PadLeft(2, '0');//对遍历到的字节进行加密

具体来说,这段代码执行以下操作:

  • 使用 for 循环遍历字节数组 md5data 中的每个字节。
  • 将当前字节转换为十六进制字符串,使用 “x” 格式说明符表示。例如,字节值 0x1A 将转换为字符串 “1a”。
  • 使用 PadLeft 方法将转换后的十六进制字符串左对齐,确保其长度为 2。如果字符串长度小于 2,将用字符 ‘0’ 在左侧填充。例如,字符串 “1a” 将被转换为 “01a”。
  • 将处理后的十六进制字符串追加到字符串变量 str 中。
  • 通过这些操作,原始字节数据将被转换为一个包含十六进制字符的字符串。这是 MD5 加密过程的一部分,最终将生成一个 32 个字符的 MD5 哈希值。

4.ComputeHash(Byte[])

计算指定字节数组的哈希值。

public byte[] ComputeHash (byte[] buffer);
 
参数
buffer    Byte[]
要计算其哈希代码的输入。
 
返回
Byte[]
计算所得的哈希代码。
 
例外
ArgumentNullException
buffer 为 null。
 
ObjectDisposedException
对象已被释放。

二、使用MD5算法对密码进行加密

// 使用MD5算法对密码进行加密
using System.Security.Cryptography;
namespace _155
{
    class Program
    {
        /// <summary>
        /// 对遍历到的字节进行加密
        /// </summary>
        /// <param name="strPwd">输入的待加密的字符串</param>
        /// <returns name="str">返回加密后的值</returns>
        public static string Encrypt(string strPwd)
        {
            MD5 md5 = MD5.Create();
            byte[] data = System.Text.Encoding.Default.GetBytes(strPwd);//将字符编码为一个字节序列
            byte[] md5data = md5.ComputeHash(data);                     //计算data字节数组的哈希值
            md5.Clear();       //清空MD5对象
            string str = "";   //定义一个变量,用来记录加密后的密码
            for (int i = 0; i < md5data.Length - 1; i++)
            {
                str += md5data[i].ToString("x").PadLeft(2, '0');
            }
            return str;
        }
 
        static void Main(string[] args)
        {
            ArgumentNullException.ThrowIfNull(args);
 
            while (true)
            {
                Console.Write("请输入密码:");
                string P_str_Code = Console.ReadLine()!;
                Console.WriteLine("使用MD5加密后的结果为:" + Encrypt(P_str_Code));
            }
        }
    }
}
//运行结果:
/*
请输入密码:123456789Qq
使用MD5加密后的结果为:6d28b4834bd6a9e384be01c131a8f2
请输入密码:123456789QQ
使用MD5加密后的结果为:46e7640c5b2ddeab142d71d872163b
请输入密码:123456789qq
使用MD5加密后的结果为:9c32d6523556378b8b1632720f7ab1
请输入密码:
 */

到此这篇关于C#使用MD5算法对密码进行加密的示例代码的文章就介绍到这了,更多相关C# MD5算法密码加密内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • C# WinForm国际化实现的简单方法

    C# WinForm国际化实现的简单方法

    这篇文章主要介绍了C# WinForm国际化实现的简单方法,有需要的朋友可以参考一下
    2014-01-01
  • C#中Json的简单处理方法

    C#中Json的简单处理方法

    这篇文章主要介绍了C#中Json的简单处理方法的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2016-09-09
  • C# 操作Windows注册表的实现方法

    C# 操作Windows注册表的实现方法

    本文主要介绍了C# 操作Windows注册表的实现方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-03-03
  • C#实现HTTP下载文件的方法

    C#实现HTTP下载文件的方法

    这篇文章主要介绍了C#实现HTTP下载文件的方法,包括了HTTP通信的创建、本地文件的写入等,非常具有实用价值,需要的朋友可以参考下
    2014-11-11
  • C#设计模式之Template模板方法模式实现ASP.NET自定义控件 密码强度检测功能

    C#设计模式之Template模板方法模式实现ASP.NET自定义控件 密码强度检测功能

    这篇文章主要介绍了C#设计模式之Template模板方法模式实现ASP.NET自定义控件 密码强度检测功能,简单介绍了模板方法模式的定义、原理及检测密码强度的相关使用技巧,需要的朋友可以参考下
    2017-09-09
  • c#压缩字符串的方法

    c#压缩字符串的方法

    这篇文章主要介绍了c#压缩字符串的方法,文中示例代码非常详细,供大家参考和学习,感兴趣的朋友可以了解下
    2020-06-06
  • C#键值对容器的介绍

    C#键值对容器的介绍

    C#键值对容器的介绍,需要的朋友可以参考一下
    2013-05-05
  • C#泛型相关讲解

    C#泛型相关讲解

    我们在编写程序时,经常 遇到两个模块的功能非常相似,只是一个是处理int数据,另一个是处理string数据,或者其他自定义的数据类型
    2013-05-05
  • 关于C#执行顺序带来的一些潜在问题

    关于C#执行顺序带来的一些潜在问题

    这篇文章主要给大家介绍了关于C#执行顺序带来的一些潜在问题,文中通过示例代码介绍的非常详细,对大家学习或者使用C#具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2020-08-08
  • c# 编写的简单飞行棋游戏

    c# 编写的简单飞行棋游戏

    这个简单的飞行棋游戏主要是讲的方法怎么应用,充分的去理解方法和方法的调用。整体收获还是很大的。感兴趣的朋友可以参考下
    2021-06-06

最新评论