C#的MD5加密解密的通用操作类

原创 2011年01月18日 15:35:00

using System.Security.Cryptography; 

namespace ...

{

  /// <summary>
    /// MD5加密解密的通用操作类
    /// 说明:java加密后的密码,与此处的对比相同。
    /// </summary>
    public static class MD5Common
    {
        /// <summary>
        /// 返回指定字符串的Md5
        /// </summary>
        /// <param name="strInput">指定字符串</param>
        /// <returns>返回字符串的Md5</returns>
        public static string GetMd5Hash(string strInput)
        {
            // Create a new instance of the MD5CryptoServiceProvider object.
            MD5 md5Hasher = MD5.Create();

            // Convert the input string to a byte array and compute the hash.
            byte[] btData = md5Hasher.ComputeHash(Encoding.Default.GetBytes(strInput));

            // Create a new Stringbuilder to collect the bytes
            // and create a string.
            StringBuilder sBuilder = new StringBuilder();

            // Loop through each byte of the hashed data
            // and format each one as a hexadecimal string.
            for (int i = 0; i < btData.Length; i++)
            {
                sBuilder.Append(btData[i].ToString("x2"));
            }

            // Return the hexadecimal string.
            return sBuilder.ToString();
        }

        /// <summary>
        /// 检查一个普通字符串的Md5,与传递的Md5字符串是否相同
        /// </summary>
        /// <param name="strInput">普通字符串</param>
        /// <param name="strHash">Md5字符串</param>
        /// <returns>返回是否相同</returns>
        public static bool VerifyMd5Hash(string strInput, string strHash)
        {
            // Hash the input.
            string strhashOfInput = GetMd5Hash(strInput);

            // Create a StringComparer an comare the hashes.
            StringComparer comparer = StringComparer.OrdinalIgnoreCase;

            if (0 == comparer.Compare(strhashOfInput, strHash))
            {
                return true;
            }
            else
            {
                return false;
            }
        }

    }

}

版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

C#中使用MD5加密的方法

文章介绍了五种使用MD5的方法,提供一种思路和参考,实例1是一种较安全的方法。如果不支持中文,可将中文编码取出进行MD5加密。本文中的所有方法均来自网络,感谢各位作者提供。

c#中MD5的加密解密

c#中MD5的加密解密ASP.NET技术文章2009-08-04 16:54:49阅读55评论0字号:大中小从网上找到了一些相关的资料然后自己试着做了一下觉得收益匪浅。其实对MD5的加密解密,我们知道...

C# winform 实现MD5加密功能

C# winform 实现MD5加密功能  : MD5的全称是message-digest algorithm 5(信息-摘要算法,在90年代初由mit laboratory f...

C# 常用加密解密方法

字符串加密分可逆和不可逆加密两种,下面直接贴上代码 using System; using System.Collections.Generic; using System.Text; using...

C# MD5加密解密类 winform

C#MD5加密解密

C# 常见加密解密类

大部分的加密类的使用方式是差不多的,其中MD5和SHA类似,均为不可逆;RSA位可加可解;DES和AES类似,均需要加密向量;文中所有明文加密后都转为了净荷明文。没必要转Byte转16进制字符串(难为...
  • hotmee
  • hotmee
  • 2016-09-19 11:14
  • 2679

C#使用MD5加密,DES加密解密的一个类

没什么好说的,直接上类。 using System; using System.IO; using System.Security.Cryptography; using System.Text; ...

c#MD5加密TripleDES加密解密封装

public static string EncMd5(string str) { //获取加密服务 System.Security...

C#实现MD5加密

C#实现MD5加密。 1、创建MD5Str.cs加密处理类 public class MD5Str { /// /// 字符串MD5加密 /// /// 要加密...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)