using System;
using System.IO;
using System.Security.Cryptography;
using System.Text; /// <summary>
/// Encrypt 的摘要说明
/// </summary>
public static class Encrypt
{
    #region 解密由AES加密的字符串
    /// <summary>
    /// 解密由AES加密的字符串
    /// </summary>
    /// <param name="source">加密字符串</param>
    /// <param name="key">加密密钥</param>
    /// <returns>解密后的字符串</returns>
    public static string Dencrypt_AES(string source, string key)
    {
        try
        {
            Rijndael rijndael = Rijndael.Create();
            rijndael.Key = Encoding.Default.GetBytes(key);
            rijndael.IV = Encoding.Default.GetBytes(key.Substring(0, 0x10));
            byte[] buffer = Convert.FromBase64String(source);
            MemoryStream stream = new MemoryStream();
            CryptoStream stream2 = new CryptoStream(stream, rijndael.CreateDecryptor(), CryptoStreamMode.Write);
            stream2.Write(buffer, 0, buffer.Length);
            stream2.FlushFinalBlock();
            return Encoding.Default.GetString(stream.ToArray());
        }
        catch
        {
            return null;
        }
    }
    #endregion     #region 解密由DES加密的字符串
    /// <summary>
    /// 解密由DES加密的字符串
    /// </summary>
    /// <param name="source">加密的字符串</param>
    /// <param name="key">加密的密钥</param>
    /// <returns>解密后的字符串</returns>
    public static string Dencrypt_DES(string source, string key)
    {
        try
        {
            DESCryptoServiceProvider provider2 = new DESCryptoServiceProvider
            {
                Key = Encoding.Default.GetBytes(key),
                IV = Encoding.Default.GetBytes(key)
            };
            DESCryptoServiceProvider provider = provider2;
            byte[] buffer = Convert.FromBase64String(source);
            MemoryStream stream = new MemoryStream();
            CryptoStream stream2 = new CryptoStream(stream, provider.CreateDecryptor(), CryptoStreamMode.Write);
            stream2.Write(buffer, 0, buffer.Length);
            stream2.FlushFinalBlock();
            return Encoding.Default.GetString(stream.ToArray());
        }
        catch
        {
            return null;
        }
    }
    #endregion     #region 解密由RC2加密的字符串
    /// <summary>
    /// 解密由RC2加密的字符串
    /// </summary>
    /// <param name="source">加密的字符串</param>
    /// <param name="key">加密的密钥</param>
    /// <returns>解密后的字符串</returns>
    public static string DEncrypt_RC2(string source, string key)
    {
        try
        {
            RC2CryptoServiceProvider provider2 = new RC2CryptoServiceProvider
            {
                Key = Encoding.Default.GetBytes(key),
                IV = Encoding.Default.GetBytes(key)
            };
            RC2CryptoServiceProvider provider = provider2;
            byte[] buffer = Convert.FromBase64String(source);
            MemoryStream stream = new MemoryStream();
            CryptoStream stream2 = new CryptoStream(stream, provider.CreateDecryptor(), CryptoStreamMode.Write);
            stream2.Write(buffer, 0, buffer.Length);
            stream2.FlushFinalBlock();
            return Encoding.Default.GetString(stream.ToArray());
        }
        catch
        {
            return null;
        }
    }
    #endregion     #region 解密由TripleDES加密的字符串
    /// <summary>
    /// 解密由TripleDES加密的字符串
    /// </summary>
    /// <param name="source">加密的字符串</param>
    /// <param name="key">加密的密钥</param>
    /// <returns>解密后的字符串</returns>
    public static string Dencrypt_TripleDES(string source, string key)
    {
        try
        {
            TripleDESCryptoServiceProvider provider2 = new TripleDESCryptoServiceProvider
            {
                Key = Encoding.Default.GetBytes(key),
                IV = Encoding.Default.GetBytes(key.Substring(0, 8))
            };
            TripleDESCryptoServiceProvider provider = provider2;
            byte[] buffer = Convert.FromBase64String(source);
            MemoryStream stream = new MemoryStream();
            CryptoStream stream2 = new CryptoStream(stream, provider.CreateDecryptor(), CryptoStreamMode.Write);
            stream2.Write(buffer, 0, buffer.Length);
            stream2.FlushFinalBlock();
            return Encoding.Default.GetString(stream.ToArray());
        }
        catch
        {
            return null;
        }
    }
    #endregion     #region 使用AES方式进行加密
    /// <summary>
    /// 使用AES方式进行加密
    /// </summary>
    /// <param name="source">需要加密的字符串</param>
    /// <param name="key">加密用的密钥</param>
    /// <returns>加密后的字符串</returns>
    public static string Encrypt_AES(string source, string key)
    {
        try
        {
            Rijndael rijndael = Rijndael.Create();
            rijndael.Key = Encoding.Default.GetBytes(key);
            rijndael.IV = Encoding.Default.GetBytes(key.Substring(0, 0x10));
            byte[] bytes = Encoding.Default.GetBytes(source);
            MemoryStream stream = new MemoryStream();
            CryptoStream stream2 = new CryptoStream(stream, rijndael.CreateEncryptor(), CryptoStreamMode.Write);
            stream2.Write(bytes, 0, bytes.Length);
            stream2.FlushFinalBlock();
            return Convert.ToBase64String(stream.ToArray());
        }
        catch
        {
            return null;
        }
    }
    #endregion     #region 使用DES方式进行加密
    /// <summary>
    /// 使用DES方式进行加密
    /// </summary>
    /// <param name="source">需要加密的字符串</param>
    /// <param name="key">加密用的密钥</param>
    /// <returns>加密后的字符串</returns>
    public static string Encrypt_DES(string source, string key)
    {
        try
        {
            DESCryptoServiceProvider provider2 = new DESCryptoServiceProvider
            {
                Key = Encoding.Default.GetBytes(key),
                IV = Encoding.Default.GetBytes(key)
            };
            DESCryptoServiceProvider provider = provider2;
            byte[] bytes = Encoding.Default.GetBytes(source);
            MemoryStream stream = new MemoryStream();
            CryptoStream stream2 = new CryptoStream(stream, provider.CreateEncryptor(), CryptoStreamMode.Write);
            stream2.Write(bytes, 0, bytes.Length);
            stream2.FlushFinalBlock();
            return Convert.ToBase64String(stream.ToArray());
        }
        catch
        {
            return null;
        }
    }
    #endregion     #region 使用MD5方式进行加密
    /// <summary>
    /// 使用MD5方式进行加密
    /// </summary>
    /// <param name="source">需要加密的字符串</param>
    /// <param name="key">加密用的密钥</param>
    /// <returns>加密后的字符串</returns>
    public static string Encrypt_MD5(string source)
    {
        string str = "";
        MD5CryptoServiceProvider provider = new MD5CryptoServiceProvider();
        byte[] bytes = Encoding.Default.GetBytes(source);
        byte[] buffer2 = provider.ComputeHash(bytes);
        foreach (byte num in buffer2)
        {
            str = str + num.ToString("X").PadLeft(2, '0');
        }
        return str;
    }
    #endregion     #region 使用RC2方式进行加密
    /// <summary>
    /// 使用RC2方式进行加密
    /// </summary>
    /// <param name="source">需要加密的字符串</param>
    /// <param name="key">加密用的密钥</param>
    /// <returns>加密后的字符串</returns>
    public static string Encrypt_RC2(string source, string key)
    {
        try
        {
            RC2CryptoServiceProvider provider2 = new RC2CryptoServiceProvider
            {
                Key = Encoding.Default.GetBytes(key),
                IV = Encoding.Default.GetBytes(key)
            };
            RC2CryptoServiceProvider provider = provider2;
            byte[] bytes = Encoding.Default.GetBytes(source);
            MemoryStream stream = new MemoryStream();
            CryptoStream stream2 = new CryptoStream(stream, provider.CreateEncryptor(), CryptoStreamMode.Write);
            stream2.Write(bytes, 0, bytes.Length);
            stream2.FlushFinalBlock();
            return Convert.ToBase64String(stream.ToArray());
        }
        catch
        {
            return null;
        }
    }
    #endregion     #region 使用TripleDES方式进行加密
    /// <summary>
    /// 使用TripleDES方式进行加密
    /// </summary>
    /// <param name="source">需要加密的字符串</param>
    /// <param name="key">加密用的密钥</param>
    /// <returns>加密后的字符串</returns>
    public static string Encrypt_TripleDES(string source, string key)
    {
        try
        {
            TripleDESCryptoServiceProvider provider2 = new TripleDESCryptoServiceProvider
            {
                Key = Encoding.Default.GetBytes(key),
                IV = Encoding.Default.GetBytes(key.Substring(0, 8))
            };
            TripleDESCryptoServiceProvider provider = provider2;
            byte[] bytes = Encoding.Default.GetBytes(source);
            MemoryStream stream = new MemoryStream();
            CryptoStream stream2 = new CryptoStream(stream, provider.CreateEncryptor(), CryptoStreamMode.Write);
            stream2.Write(bytes, 0, bytes.Length);
            stream2.FlushFinalBlock();
            return Convert.ToBase64String(stream.ToArray());
        }
        catch
        {
            return null;
        }
    }
    #endregion     #region 获取加密的密钥
    /// <summary>
    /// 获取加密的密钥
    /// </summary>
    /// <param name="EncryptType">加密方式</param>
    /// <returns>密钥</returns>
    public static string GetKey(EncryptType encryptType)
    {
        switch (encryptType)
        {
            case EncryptType.AES:
                return "1zx2fqw3eas4dtg8hui9opl6dfh5aok0";             case EncryptType.DES:
                return "zxc52mxb";             case EncryptType.TDES:
                return "zxc52mxbqwdftghu24dfhji0";             case EncryptType.RC2:
                return "qwedfgbd";
        }
        return "";
    }
    #endregion     public enum EncryptType:byte
    {
        AES,
        DES,
        TDES,
        RC2
    }
}

C#常用加密方法的更多相关文章

  1. iOS常用加密方法(aes、md5、base64)

    1.代码 iOS常用加密方法(aes.md5.base64) .AES加密 NSData+AES.h文件 // // NSData-AES.h // Smile // // Created by 周 ...

  2. IOS开发之----常用加密方法

    本文转载至 http://blog.csdn.net/wildfireli/article/details/23191983 (AES.MD5.Base64) 分类: iPhone 2014-04-0 ...

  3. Java中常用的加密方法(JDK)

    加密,是以某种特殊的算法改变原有的信息数据,使得未授权的用户即使获得了已加密的信息,但因不知解密的方法,仍然无法了解信息的内容.大体上分为双向加密和单向加密,而双向加密又分为对称加密和非对称加密(有些 ...

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

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

  5. [转载] Java中常用的加密方法

    转载自http://www.iteye.com/topic/1122076/ 加密,是以某种特殊的算法改变原有的信息数据,使得未授权的用户即使获得了已加密的信息,但因不知解密的方法,仍然无法了解信息的 ...

  6. IOS常见的加密方法,常用的MD5和Base64

    iOS代码加密常用加密方式 iOS代码加密常用加密方式,常见的iOS代码加密常用加密方式算法包括MD5加密.AES加密.BASE64加密,三大算法iOS代码加密是如何进行加密的,且看下文 MD5 iO ...

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

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

  8. iOS里常见的几种信息编码、加密方法简单总结

    一.MD5 MD5编码是最常用的编码方法之一,是从一段字符串中通过相应特征生成一段32位的数字字母混合码. MD5主要特点是 不可逆,相同数据的MD5值肯定一样,不同数据的MD5值不一样(也不是绝对的 ...

  9. iOS代码加密常用加密方式

    iOS代码加密常用加密方式 iOS代码加密常用加密方式,常见的iOS代码加密常用加密方式算法包括MD5加密.AES加密.BASE64加密,三大算法iOS代码加密是如何进行加密的,且看下文 MD5 iO ...

随机推荐

  1. 生成命令行接口--google开源的fire使用体验【python-fire】

    在python中,命令行接口常用的argparse 和click,但是相对于python-fire 来说灵活度太缺了,fire可以直接将python中的函数,以命令行显示. 简单的介绍几个例子: #! ...

  2. [转]rsync命令中文文档

    原文链接 rsync是一个快速.多功能的远程(和本地)文件拷贝工具. 摘要 Local: rsync [OPTION...] SRC... [DEST] Access via remote shell ...

  3. sql 有条件计数

    select InstitutionID=LEFT(InstitutionID,9), Irregularities_Type=sum(CASE WHEN Irregularities_Type> ...

  4. mysql 线程等待时间,解决sleep进程过多的办法

    如果你没有修改过MySQL的配置,缺省情况下,wait_timeout的初始值是28800.   wait_timeout 过大有弊端,其体现就是MySQL里大量的SLEEP进程无法及时释放,拖累系统 ...

  5. spring boot 搭建

    http://www.ityouknow.com/springboot/2018/06/12/spring-boo-java-simple.html 在http://start.spring.io/下 ...

  6. 我的IT之路这样走过

    一.我的IT之路这样走过: 1.大一上学期.我们学校是用C语言做启蒙语言的:虽然我学的相当不错,但是我发现一个问题:用C语言做软件那么它的交付周期比较长. 对于我这种无产阶级来说最关键的是解眼下的粮食 ...

  7. Vue在线客服系统【开源项目】

    1. 项目介绍 一个基于Vue2.0的在线客服系统. 技术栈包含:Vue.VueX.Vue Router.Element UI. 2. 功能介绍 项目包含了2个模块:客服端和访客端. 2.1 客服端功 ...

  8. hadoop HA (no zkfc to stop) DFSZKFailoverController进程没有启动

    这个bug确实恶心的不要不要的.我一开始以为是我自己打开方式(毕竟不熟悉搭建流程,别人怎么做,我照着做) 我照着视频或者博客编写hdfs-site.xml(dfs.ha.fencing.methods ...

  9. atitit 如何才能保持基业长青,建立万年企业v2 q66.docx

    1. 价值观 1 2. 分权 民主化 扁平化管理 1 3. 剥离经济部门,,降低经济的重要性 .超越利润的追求 1 4. 构建愿景 1 5. 强大的团队文化 企业文化 宗教文化 .教派般的文化 1 1 ...

  10. Python定期删除文件、整理文件夹

    1.根据传入的参数,文件所在目录,匹配文件的正则表达式,过期天数进行删除,这些可写在配置文件del_file.conf. del_file3.py #!/usr/bin/env python # en ...