`
jilong-liang
  • 浏览: 480986 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类

C#加密帮助类EncryptHelper

    博客分类:
  • C #
MD5 
阅读更多

///之前这篇加密帮助类觉得不够严谨,不够强,所以特意修改,也对自己负责一点,如果对你有帮助可以看看,

///呵呵!~这个类都经过本人测试过都没问题.

 

using System;

using System.Collections.Generic;

using System.IO;

using System.Linq;

using System.Runtime.Serialization.Formatters.Binary;

using System.Security.Cryptography;

using System.Text;

using log4net;

 

namespace Utility

{

    /// <summary>

    /// @Author:梁继龙

    /// @Date:2012/7/30

    /// @Descripte:EncryptHelper加密帮助类.

    /// </summary>

    public class EncryptHelper

    {

        /// <summary>

        ///方法一:

        ///此种加密之后的字符串是三十二位的(字母加数据)字符串  

        /// Example: passwordadmin 加密变成后21232f297a57a5a743894a0e4a801fc3

        /// </summary>

        /// <param name="beforeStr"></param>

        /// <returns></returns>

        public string MD5Encrypt(string beforeStr)

        {

            string afterString = "";

            try

            {

                MD5 md5 = MD5.Create();

                byte[] hashs = md5.ComputeHash(Encoding.UTF8.GetBytes(beforeStr));

 

                foreach (byte by in hashs)

                    //这里是字母加上数据进行加密.//3y 可以,y3不可以或 x3j等应该是超过32位不可以

                    afterString += by.ToString("x2");

            }

            catch (Exception ex)

            {

                ILog log = log4net.LogManager.GetLogger(this.GetType());

                log.Error("==============你引起了一个错误是==============" + ex.Message.ToString());

            }

            return afterString;

        }

 

        /// <summary>

        /// 方法二

        /// HashAlgorithm加密

        /// 这种加密是  字母加-加字符  

        /// Example: passwordadmin 加密变成后19-A2-85-41-44-B6-3A-8F-76-17-A6-F2-25-01-9B-12

        /// </summary>

        /// <param name="password"></param>

        /// <returns></returns>

        public String HashEncrypt(string password)

        {

            Byte[] hashedBytes = null;

            try

            {

                Byte[] clearBytes = new UnicodeEncoding().GetBytes(password);

                hashedBytes = ((HashAlgorithm)CryptoConfig.CreateFromName("MD5")).ComputeHash(clearBytes);

            }

            catch (Exception ex)

            {

                ILog log = log4net.LogManager.GetLogger(this.GetType());

                log.Error("==============你引起了一个错误是==============" + ex.Message.ToString());

            }

            return BitConverter.ToString(hashedBytes);//MD5加密

        }

 

        /// <summary>

        /// 方法三:

        /// MD5  +   HashCode加密

        /// Example: passwordadmin 加密变成后 895b7da64943134be17b825ce118456c

        /// </summary>

        /// <returns></returns>

        public String MD5HashCodeEncrypt(string EncryptPwd)

        {

            return MD5Encrypt(HashEncrypt(EncryptPwd)); //HashEncrypt基础上再MD5

        }

 

        /// <summary>

        /// 方法四:

        /// HashCode +MD5 加密

        /// Example: passwordadmin 加密变成后EB-1D-6D-E2-FC-F1-CD-94-4D-75-78-E6-3D-7A-12-32

        /// </summary>

        /// <param name="EncryptPwd"></param>

        /// <returns></returns>

        public String HashCodeMD5Encrypt(string EncryptPwd)

        {

            return HashEncrypt(MD5Encrypt(EncryptPwd)); //MD5基础再HashCode

        }

        /// <summary>

        /// 方法五

        /// </summary>

        /// <param name="EncryptPwd"></param>

        /// <returns></returns>

 

        public String HashMD5Encrypt(string EncryptPwd)

        {

            return HashCodeMD5Encrypt(HashCodeMD5Encrypt(EncryptPwd)); //HashCodeMD5Encrypt基础再HashCode

        }

        /// <summary>

        /// 方法六

        /// 哈哈是不是有点晕呢?

        /// 大家伙可以继续写.

        /// </summary>

        /// <param name="EncryptPwd"></param>

        /// <returns></returns>

        public String MD5HashEncrypt(string EncryptPwd)

        {

            return MD5HashCodeEncrypt(MD5HashCodeEncrypt(EncryptPwd)); //MD5基础再HashCode

        }

        /// <summary>

        /// 64位双重MD5小写

        /// </summary>

        /// <returns></returns>

        public static string Last64(string s)

        {

            if (s.Length != 32)

                return "";

            string s1 = s.Substring(0, 16);

            string s2 = s.Substring(16, 16);

            return Lower32(s1) + Lower32(s2);

        }

        /// <summary>

        /// 32位大写

        /// </summary>

        /// <returns></returns>

        public static string Upper32(string s)

        {

            s = System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(s, "md5").ToString();

            return s.ToUpper();

        }

        /// <summary>

        /// 32位小写

        /// </summary>

        /// <returns></returns>

        public static string Lower32(string s)

        {

            s = System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(s, "md5").ToString();

            return s.ToLower();

        }

        /// <summary>

        /// 16位大写

        /// </summary>

        /// <returns></returns>

        public static string Upper16(string s)

        {

            s = System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(s, "md5").ToString();

            return s.ToUpper().Substring(8, 16);

        }

        /// <summary>

        /// 16位小写

        /// </summary>

        /// <returns></returns>

        public static string Lower16(string s)

        {

            s = System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(s, "md5").ToString();

            return s.ToLower().Substring(8, 16);

        }

    }

 

}

 

0
0
分享到:
评论

相关推荐

    C#ASP.NET 加密帮助类

    `MyJiaMi.cs`文件很可能包含了一个自定义的加密帮助类,用于简化加密操作。在这个帮助类中,可能会集成常见的加密算法,如对称加密(如AES、DES)、非对称加密(如RSA)以及哈希函数(如SHA、MD5)。 1. 对称加密:...

    C#加密解密类及使用说明

    本篇文章将详细探讨C#中用于加密和解密字符串的类以及其使用方法,以帮助开发者在实际项目中实现对数据的安全保护。 一、加密与解密的重要性 在互联网应用中,保存用户密码时采用明文存储是非常危险的,一旦数据库...

    一些常见的C#加密解密类(MD5,RSA,DES,RC2...)

    本资源包含了一些常见的C#加密解密类,如MD5、RSA、DES和RC2。下面将详细阐述这些算法的工作原理及其在C#中的应用。 1. **MD5(Message-Digest Algorithm 5)** MD5是一种广泛使用的哈希函数,它将任意长度的输入...

    c# 常用加密,解密类

    C#作为.NET框架下的主要编程语言,提供了丰富的加密库来帮助开发者处理数据的安全存储和传输。以下将详细介绍标题中提到的五种加密算法:MD5、DES、RC2、Rijndael(AES)以及RSA,并结合压缩包内的文件,分析它们在...

    C#加密算法类库

    C#加密算法类库是一个专为.NET开发者设计的工具,它包含了多种常见的加密算法实现,以便在C#项目中方便地进行数据加密和解密。这个类库通常以.dll文件的形式提供,允许开发者通过引用该文件来直接使用其封装好的加密...

    C#加密机制实例源码-口令加密Exe【201903】

    6. **Encoding and Formatting**:在处理字符串时,需要将字符编码为字节,如ASCII、Unicode或UTF-8,C#的Encoding类可以帮助完成这个转换。此外,加密后的数据通常需要进行Base64编码以便于存储和传输。 7. **...

    C# 加密解密类

    C# 加密解密类,可以直接附加到程序中运行,已经很完善了

    c#加密软件,提供c#加密算法类

    本软件包提供了一系列C#加密算法类,旨在帮助开发者理解和应用这些技术。以下将详细介绍C#中常见的加密算法及其应用。 1. **基本加密概念** - 加密:将明文数据转换为不可读的密文,防止未经授权的访问。 - 解密...

    C# 常用加密解密类

    C#中,我们可以使用`System.Security.Cryptography`命名空间下的`DESCryptoServiceProvider`类来实现DES加密和解密。以下是一段简单的示例代码: ```csharp using System; using System.IO; using System.Security....

    c#开发帮助类.zip

    除了数据访问,C#帮助类还可以涵盖其他领域,如日期时间处理、字符串操作、文件系统操作、网络通信、加密解密、XML/JSON序列化等。例如,一个名为`Helper`的静态类可能包含以下方法: - `GetDateTimeNow()`:返回...

    C#各种加密方式的 加密、解密 小工具,可以直接运行的源码 含类库文件

    对于初学者或开发者来说,这个项目是一个很好的学习资源,可以帮助理解和实践C#中的加密技术。通过编译和运行源代码,可以更直观地了解这些算法的工作原理,并在实际项目中灵活运用。同时,也可以根据需要扩展或修改...

    C#加密和解密

    C#加密和解密C#加密和解密C#加密和解密C#加密和解密

    C# 读写加密狗 实例源码(硬件读写)

    在C#中,可以使用System.Security.Cryptography命名空间提供的类来实现这些加密操作。 此外,为了简化读写过程,开发者可能会编写一些辅助类或库,封装串口通信和加密解密的细节,提供更高级别的API供其他部分的...

    C#加密类的使用.ppt

    总之,C#通过`.NET Framework`的`System.Security.Cryptography`命名空间提供了一系列强大的加密工具,帮助开发者实现数据安全的多种操作,包括非对称加密、对称加密、哈希计算和数字签名等,确保了应用程序的安全性...

    C# 文件加密 实例源码(加密解密)

    在C#编程中,文件加密是一项重要的安全...以上就是关于"C# 文件加密 实例源码(加密解密)"涉及的关键知识点,希望对你理解和实现文件加密有所帮助。通过深入学习和实践,你可以更好地保护你的应用程序中的敏感数据。

    C# 10种加密解密方式

    C#的`Random`类可以生成基本的随机数,而`System.Security.Cryptography`命名空间提供了更安全的随机数生成器。 7. **文件加密**:C#可以对整个文件或文件的部分内容进行加密,例如使用AES(高级加密标准)算法。...

    C#实现加密狗

    综上所述,使用C#实现加密狗的功能涉及多方面的知识,包括C#编程、文件操作、加密解密、硬件交互、错误处理以及程序设计和测试。通过学习和实践这些知识点,开发者可以构建出安全可靠的加密狗解决方案。

    C#加密解密(自定义加密字符)

    带加密字符的 加密 解密方法 static string encryptKey = "加密字符"; 自定义加密字符(加密解密必须一致才能解密) ///   /// 加密字符串 ///   ///  name="str"&gt;要加密的字符串  /// 加密后的...

    C#加密算法汇总

    在C#中,可以利用`System.Web.Security.FormsAuthentication`类的`HashPasswordForStoringInConfigFile`方法实现SHA1加密,如下面的代码所示: ```csharp public string SHA1(string source) { return Forms...

    加密解密类(C#)

    用于加密解密的操作类。

Global site tag (gtag.js) - Google Analytics