public static class EncryptUtil
{
    #region MD5加密

    /// <summary>
    /// MD5加密
    /// </summary>
    public static string Md532(this string value)
    {
        if (value == null)
        {
            throw new ArgumentNullException("未将对象引用设置到对象的实例。");
        }

        var encoding = Encoding.UTF8;
        MD5 md5 = MD5.Create();
        return HashAlgorithmBase(md5, value, encoding);
    }

    /// <summary>
    /// 加权MD5加密
    /// </summary>
    public static string Md532(this string value, string salt)
    {
        return salt == null ? value.Md532() : (value + "『" + salt + "』").Md532();
    }

    #endregion

    #region SHA 加密

    /// <summary>
    /// SHA1 加密
    /// </summary>
    public static string Sha1(this string value)
    {
        if (value == null)
        {
            throw new ArgumentNullException("未将对象引用设置到对象的实例。");
        }

        var encoding = Encoding.UTF8;
        SHA1 sha1 = new SHA1CryptoServiceProvider();
        return HashAlgorithmBase(sha1, value, encoding);
    }

    /// <summary>
    /// SHA256 加密
    /// </summary>
    public static string Sha256(this string value)
    {
        if (value == null)
        {
            throw new ArgumentNullException("未将对象引用设置到对象的实例。");
        }

        var encoding = Encoding.UTF8;
        SHA256 sha256 = new SHA256Managed();
        return HashAlgorithmBase(sha256, value, encoding);
    }

    /// <summary>
    /// SHA512 加密
    /// </summary>
    public static string Sha512(this string value)
    {
        if (value == null)
        {
            throw new ArgumentNullException("未将对象引用设置到对象的实例。");
        }
        var encoding = Encoding.UTF8;
        SHA512 sha512 = new SHA512Managed();
        return HashAlgorithmBase(sha512, value, encoding);
    }

    #endregion

    #region HMAC 加密

    /// <summary>
    /// HmacSha1 加密
    /// </summary>
    public static string HmacSha1(this string value, string keyVal)
    {
        if (value == null)
        {
            throw new ArgumentNullException("未将对象引用设置到对象的实例。");
        }
        var encoding = Encoding.UTF8;
        byte[] keyStr = encoding.GetBytes(keyVal);
        HMACSHA1 hmacSha1 = new HMACSHA1(keyStr);
        return HashAlgorithmBase(hmacSha1, value, encoding);
    }

    /// <summary>
    /// HmacSha256 加密
    /// </summary>
    public static string HmacSha256(this string value, string keyVal)
    {
        if (value == null)
        {
            throw new ArgumentNullException("未将对象引用设置到对象的实例。");
        }
        var encoding = Encoding.UTF8;
        byte[] keyStr = encoding.GetBytes(keyVal);
        HMACSHA256 hmacSha256 = new HMACSHA256(keyStr);
        return HashAlgorithmBase(hmacSha256, value, encoding);
    }

    /// <summary>
    /// HmacSha384 加密
    /// </summary>
    public static string HmacSha384(this string value, string keyVal)
    {
        if (value == null)
        {
            throw new ArgumentNullException("未将对象引用设置到对象的实例。");
        }
        var encoding = Encoding.UTF8;
        byte[] keyStr = encoding.GetBytes(keyVal);
        HMACSHA384 hmacSha384 = new HMACSHA384(keyStr);
        return HashAlgorithmBase(hmacSha384, value, encoding);
    }

    /// <summary>
    /// HmacSha512 加密
    /// </summary>
    public static string HmacSha512(this string value, string keyVal)
    {
        if (value == null)
        {
            throw new ArgumentNullException("未将对象引用设置到对象的实例。");
        }
        var encoding = Encoding.UTF8;
        byte[] keyStr = encoding.GetBytes(keyVal);
        HMACSHA512 hmacSha512 = new HMACSHA512(keyStr);
        return HashAlgorithmBase(hmacSha512, value, encoding);
    }

    /// <summary>
    /// HmacMd5 加密
    /// </summary>
    public static string HmacMd5(this string value, string keyVal)
    {
        if (value == null)
        {
            throw new ArgumentNullException("未将对象引用设置到对象的实例。");
        }
        var encoding = Encoding.UTF8;
        byte[] keyStr = encoding.GetBytes(keyVal);
        HMACMD5 hmacMd5 = new HMACMD5(keyStr);
        return HashAlgorithmBase(hmacMd5, value, encoding);
    }

    /// <summary>
    /// HmacRipeMd160 加密
    /// </summary>
    public static string HmacRipeMd160(this string value, string keyVal)
    {
        if (value == null)
        {
            throw new ArgumentNullException("未将对象引用设置到对象的实例。");
        }
        var encoding = Encoding.UTF8;
        byte[] keyStr = encoding.GetBytes(keyVal);
        HMACRIPEMD160 hmacRipeMd160 = new HMACRIPEMD160(keyStr);
        return HashAlgorithmBase(hmacRipeMd160, value, encoding);
    }

    #endregion

    #region AES 加密解密

    /// <summary>
    /// AES加密
    /// </summary>
    /// <param name="value">待加密字段</param>
    /// <param name="keyVal">密钥值</param>
    /// <param name="ivVal">加密辅助向量</param>
    /// <returns></returns>
    public static string AesStr(this string value, string keyVal, string ivVal)
    {
        if (value == null)
        {
            throw new ArgumentNullException("未将对象引用设置到对象的实例。");
        }

        var encoding = Encoding.UTF8;
        byte[] btKey = keyVal.FormatByte(encoding);
        byte[] btIv = ivVal.FormatByte(encoding);
        byte[] byteArray = encoding.GetBytes(value);
        string encrypt;
        Rijndael aes = Rijndael.Create();
        using (MemoryStream mStream = new MemoryStream())
        {
            using (CryptoStream cStream = new CryptoStream(mStream, aes.CreateEncryptor(btKey, btIv), CryptoStreamMode.Write))
            {
                cStream.Write(byteArray, , byteArray.Length);
                cStream.FlushFinalBlock();
                encrypt = Convert.ToBase64String(mStream.ToArray());
            }
        }
        aes.Clear();
        return encrypt;
    }

    /// <summary>
    /// AES解密
    /// </summary>
    /// <param name="value">待加密字段</param>
    /// <param name="keyVal">密钥值</param>
    /// <param name="ivVal">加密辅助向量</param>
    /// <returns></returns>
    public static string UnAesStr(this string value, string keyVal, string ivVal)
    {
        var encoding = Encoding.UTF8;
        byte[] btKey = keyVal.FormatByte(encoding);
        byte[] btIv = ivVal.FormatByte(encoding);
        byte[] byteArray = Convert.FromBase64String(value);
        string decrypt;
        Rijndael aes = Rijndael.Create();
        using (MemoryStream mStream = new MemoryStream())
        {
            using (CryptoStream cStream = new CryptoStream(mStream, aes.CreateDecryptor(btKey, btIv), CryptoStreamMode.Write))
            {
                cStream.Write(byteArray, , byteArray.Length);
                cStream.FlushFinalBlock();
                decrypt = encoding.GetString(mStream.ToArray());
            }
        }
        aes.Clear();
        return decrypt;
    }

    /// <summary>
    /// AES Byte类型 加密
    /// </summary>
    /// <param name="data">待加密明文</param>
    /// <param name="keyVal">密钥值</param>
    /// <param name="ivVal">加密辅助向量</param>
    /// <returns></returns>
    public static byte[] AesByte(this byte[] data, string keyVal, string ivVal)
    {
        ];
        Array.Copy(Encoding.UTF8.GetBytes(keyVal.PadRight(bKey.Length)), bKey, bKey.Length);
        ];
        Array.Copy(Encoding.UTF8.GetBytes(ivVal.PadRight(bVector.Length)), bVector, bVector.Length);
        byte[] cryptograph;
        Rijndael aes = Rijndael.Create();
        try
        {
            using (MemoryStream mStream = new MemoryStream())
            {
                using (CryptoStream cStream = new CryptoStream(mStream, aes.CreateEncryptor(bKey, bVector), CryptoStreamMode.Write))
                {
                    cStream.Write(data, , data.Length);
                    cStream.FlushFinalBlock();
                    cryptograph = mStream.ToArray();
                }
            }
        }
        catch
        {
            cryptograph = null;
        }
        return cryptograph;
    }

    /// <summary>
    /// AES Byte类型 解密
    /// </summary>
    /// <param name="data">待解密明文</param>
    /// <param name="keyVal">密钥值</param>
    /// <param name="ivVal">加密辅助向量</param>
    /// <returns></returns>
    public static byte[] UnAesByte(this byte[] data, string keyVal, string ivVal)
    {
        ];
        Array.Copy(Encoding.UTF8.GetBytes(keyVal.PadRight(bKey.Length)), bKey, bKey.Length);
        ];
        Array.Copy(Encoding.UTF8.GetBytes(ivVal.PadRight(bVector.Length)), bVector, bVector.Length);
        byte[] original;
        Rijndael aes = Rijndael.Create();
        try
        {
            using (MemoryStream mStream = new MemoryStream(data))
            {
                using (CryptoStream cStream = new CryptoStream(mStream, aes.CreateDecryptor(bKey, bVector), CryptoStreamMode.Read))
                {
                    using (MemoryStream originalMemory = new MemoryStream())
                    {
                        ];
                        int readBytes;
                        , buffer.Length)) > )
                        {
                            originalMemory.Write(buffer, , readBytes);
                        }

                        original = originalMemory.ToArray();
                    }
                }
            }
        }
        catch
        {
            original = null;
        }
        return original;
    }

    #endregion

    #region DES 加密解密

    /// <summary>
    /// DES 加密
    /// </summary>
    public static string Des(this string value, string keyVal, string ivVal)
    {
        try
        {
            byte[] data = Encoding.UTF8.GetBytes(value);
             ? keyVal.Substring(, ) : keyVal), IV = Encoding.ASCII.GetBytes(ivVal.Length >  ? ivVal.Substring(, ) : ivVal) };
            var desencrypt = des.CreateEncryptor();
            , data.Length);
            return BitConverter.ToString(result);
        }
        catch { return "转换出错!"; }
    }

    /// <summary>
    /// DES 解密
    /// </summary>
    public static string UnDes(this string value, string keyVal, string ivVal)
    {
        try
        {
            string[] sInput = value.Split("-".ToCharArray());
            byte[] data = new byte[sInput.Length];
            ; i < sInput.Length; i++)
            {
                data[i] = byte.Parse(sInput[i], NumberStyles.HexNumber);
            }
             ? keyVal.Substring(, ) : keyVal), IV = Encoding.ASCII.GetBytes(ivVal.Length >  ? ivVal.Substring(, ) : ivVal) };
            var desencrypt = des.CreateDecryptor();
            , data.Length);
            return Encoding.UTF8.GetString(result);
        }
        catch { return "解密出错!"; }
    }

    #endregion

    #region BASE64 加密解密

    /// <summary>
    /// BASE64 加密
    /// </summary>
    /// <param name="value">待加密字段</param>
    /// <returns></returns>
    public static string Base64(this string value)
    {
        var btArray = Encoding.UTF8.GetBytes(value);
        , btArray.Length);
    }

    /// <summary>
    /// BASE64 解密
    /// </summary>
    /// <param name="value">待解密字段</param>
    /// <returns></returns>
    public static string UnBase64(this string value)
    {
        var btArray = Convert.FromBase64String(value);
        return Encoding.UTF8.GetString(btArray);
    }

    #endregion

    #region Base64加密解密
    /// <summary>
    /// Base64加密 可逆
    /// </summary>
    /// <param name="value">待加密文本</param>
    /// <returns></returns>
    public static string Base64Encrypt(string value)
    {
        return Convert.ToBase64String(System.Text.Encoding.Default.GetBytes(value));
    }

    /// <summary>
    /// Base64解密
    /// </summary>
    /// <param name="ciphervalue">密文</param>
    /// <returns></returns>
    public static string Base64Decrypt(string ciphervalue)
    {
        return System.Text.Encoding.Default.GetString(System.Convert.FromBase64String(ciphervalue));
    }
    #endregion

    #region 内部方法

    /// <summary>
    /// 转成数组
    /// </summary>
    private static byte[] Str2Bytes(this string source)
    {
        source = source.Replace(" ", "");
        ];
        ; i < source.Length; i += ) buffer[i / ] = Convert.ToByte(source.Substring(i, ), );
        return buffer;
    }

    /// <summary>
    /// 转换成字符串
    /// </summary>
    private static string Bytes2Str(this IEnumerable<byte> source, string formatStr = "{0:X2}")
    {
        StringBuilder pwd = new StringBuilder();
        foreach (byte btStr in source) { pwd.AppendFormat(formatStr, btStr); }
        return pwd.ToString();
    }

    private static byte[] FormatByte(this string strVal, Encoding encoding)
    {
        , ).ToUpper());
    }

    /// <summary>
    /// HashAlgorithm 加密统一方法
    /// </summary>
    private static string HashAlgorithmBase(HashAlgorithm hashAlgorithmObj, string source, Encoding encoding)
    {
        byte[] btStr = encoding.GetBytes(source);
        byte[] hashStr = hashAlgorithmObj.ComputeHash(btStr);
        return hashStr.Bytes2Str();
    }

    #endregion

}

C# 常用加密解密帮助类的更多相关文章

  1. ASP.NET常用加密解密方法

    ASP.NET常用加密解密方法 一.MD5加密解密 1.加密 C# 代码           public static string ToMd5(string clearString)        ...

  2. 2019-2-20C#开发中常用加密解密方法解析

    C#开发中常用加密解密方法解析 一.MD5加密算法 我想这是大家都常听过的算法,可能也用的比较多.那么什么是MD5算法呢?MD5全称是 message-digest algorithm 5[|ˈmes ...

  3. AES加密解密 助手类 CBC加密模式

    "; string result1 = AESHelper.AesEncrypt(str); string result2 = AESHelper.AesDecrypt(result1); ...

  4. php加密解密功能类

    这两天突发奇想想要用php写一个对日常项目加密以及解密的功能,经过努力简单的封装了一个对php代码进行加密解密的类,一些思想也是来自于网络,初步测试用着还行,可以实现对指定项目的加密以及解密(只针对本 ...

  5. C# MD5加密解密帮助类

    /// <summary>    /// MD5加密解密帮助类    /// </summary>    public static class DESHelper    {  ...

  6. php加密解密处理类

    [PHP]代码 <?php /*=========================================================== = 版权协议: = GPL (The GN ...

  7. .Net(c#)加密解密工具类:

    /// <summary> /// .Net加密解密帮助类 /// </summary> public class NetCryptoHelper { #region des实 ...

  8. Base64加密解密工具类

    使用Apache commons codec类Base64进行加密解密 maven依赖 <dependency> <groupId>commons-codec</grou ...

  9. php实现的三个常用加密解密功能函数示例

    目录 算法一: 算法二: 算法三(改进第一个加密之后的算法) 本文实例讲述了php实现的三个常用加密解密功能函数.分享给大家供大家参考,具体如下: 算法一: //加密函数 function lock_ ...

随机推荐

  1. 剑指Offer面试题:1.实现Singleton模式

    说来惭愧,自己在毕业之前就该好好看看<剑指Offer>这本书的,但是各种原因就是没看,也因此错过了很多机会,后悔莫及.但是后悔是没用的,现在趁还有余力,把这本书好好看一遍,并通过C#通通实 ...

  2. iOS开发系列--IOS程序开发概览

    概览 终于到了真正接触IOS应用程序的时刻了,之前我们花了很多时间去讨论C语言.ObjC等知识,对于很多朋友而言开发IOS第一天就想直接看到成果,看到可以运行的IOS程序.但是这里我想强调一下,前面的 ...

  3. linux 使用fdisk分区扩容

    标签:fdisk分区 概述 我们管理的服务器可能会随着业务量的不断增长造成磁盘空间不足的情况,在这个时候我们就需要增加磁盘空间,本章主要介绍如何使用fdisk分区工具创建磁盘分区和挂载分区,介绍两种情 ...

  4. SQL Server 索引和表体系结构(包含列索引)

    包含列索引 概述 包含列索引也是非聚集索引,索引结构跟聚集索引结构是一样,有一点不同的地方就是包含列索引的非键列只存储在叶子节点:包含列索引的列分为键列和非键列,所谓的非键列就是INCLUDE中包含的 ...

  5. 《R in Action》读书笔记(3) 数据变换

    MindMapper 原文件

  6. Module-Zero之租户管理

    返回<Module Zero学习目录> 开启多租户 租户实体 租户管理者 默认租户 开启多租户 ABP和Module-Zero可以运行多租户或单租户模式.多租户默认是禁用的.我们可以在mo ...

  7. ASP.net 常用服务器控件

    新人初学,有错请指,大神轻喷. .net中有HTML控件和标准服务器控件. 老师教学用的是vs2010是这样分的,不知道15里是不是这样. 如果使用HTML控件我们就会发现页面中加载了原本HTML代码 ...

  8. Atitit 图像处理知识点体系知识图谱 路线图attilax总结 v4 qcb.xlsx

    Atitit 图像处理知识点体系知识图谱 路线图attilax总结 v4 qcb.xlsx 分类 图像处理知识点体系 v2 qb24.xlsx 分类 分类 理论知识 图像金字塔 常用底层操作 卷积扫描 ...

  9. LINQ系列:LINQ to SQL Where条件

    1. 单一条件查询 var expr = context.Products .Where(p => p.ProductName == "LINQ to SQL"); SELE ...

  10. Entity Framework Code First执行SQL语句、视图及存储过程

    1.Entity Framework Code First查询视图 Entity Framework Code First目前还没有特别针对View操作的方法,但对于可更新的视图,可以采用与Table ...