C#常用加密方法
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#常用加密方法的更多相关文章
- iOS常用加密方法(aes、md5、base64)
1.代码 iOS常用加密方法(aes.md5.base64) .AES加密 NSData+AES.h文件 // // NSData-AES.h // Smile // // Created by 周 ...
- IOS开发之----常用加密方法
本文转载至 http://blog.csdn.net/wildfireli/article/details/23191983 (AES.MD5.Base64) 分类: iPhone 2014-04-0 ...
- Java中常用的加密方法(JDK)
加密,是以某种特殊的算法改变原有的信息数据,使得未授权的用户即使获得了已加密的信息,但因不知解密的方法,仍然无法了解信息的内容.大体上分为双向加密和单向加密,而双向加密又分为对称加密和非对称加密(有些 ...
- ASP.NET常用加密解密方法
ASP.NET常用加密解密方法 一.MD5加密解密 1.加密 C# 代码 public static string ToMd5(string clearString) ...
- [转载] Java中常用的加密方法
转载自http://www.iteye.com/topic/1122076/ 加密,是以某种特殊的算法改变原有的信息数据,使得未授权的用户即使获得了已加密的信息,但因不知解密的方法,仍然无法了解信息的 ...
- IOS常见的加密方法,常用的MD5和Base64
iOS代码加密常用加密方式 iOS代码加密常用加密方式,常见的iOS代码加密常用加密方式算法包括MD5加密.AES加密.BASE64加密,三大算法iOS代码加密是如何进行加密的,且看下文 MD5 iO ...
- 2019-2-20C#开发中常用加密解密方法解析
C#开发中常用加密解密方法解析 一.MD5加密算法 我想这是大家都常听过的算法,可能也用的比较多.那么什么是MD5算法呢?MD5全称是 message-digest algorithm 5[|ˈmes ...
- iOS里常见的几种信息编码、加密方法简单总结
一.MD5 MD5编码是最常用的编码方法之一,是从一段字符串中通过相应特征生成一段32位的数字字母混合码. MD5主要特点是 不可逆,相同数据的MD5值肯定一样,不同数据的MD5值不一样(也不是绝对的 ...
- iOS代码加密常用加密方式
iOS代码加密常用加密方式 iOS代码加密常用加密方式,常见的iOS代码加密常用加密方式算法包括MD5加密.AES加密.BASE64加密,三大算法iOS代码加密是如何进行加密的,且看下文 MD5 iO ...
随机推荐
- CentOS7 使用yum命令安装Java SDK(openjdk)
CentOS 6.X 和 7.X 自带有OpenJDK runtime environment (openjdk).它是一个在linux上实现开源的java 平台. 安装方式: 1.输入以下命令,以 ...
- Saltstack之Scheduler
一.引言: 在日常的运维工作中经常会遇到需要定时定点启动任务,首先会考虑到crontab,但是通过crontab的话需要每台机器下进行设置,这样统一管理的话比较复杂:通过查百度和google发现sal ...
- 整体C#与Sql培训内容及结构
图如果看不清可以右键存图片到本地
- ThreadPoolExcutor 线程池 异常处理 (下篇)
前言 因为这是之前面试的一个题目,所以印象比较深刻,前几天写了一篇文章:ThreadPoolExcutor 线程池 异常处理 (上篇) 中已经介绍了线程池异常的一些问题以及一步步分析了里面的一些源代码 ...
- 【OCR技术系列之七】端到端不定长文字识别CRNN算法详解
在以前的OCR任务中,识别过程分为两步:单字切割和分类任务.我们一般都会讲一连串文字的文本文件先利用投影法切割出单个字体,在送入CNN里进行文字分类.但是此法已经有点过时了,现在更流行的是基于深度学习 ...
- Delphi目录监控、目录监听
资料地址: 1.https://www.cnblogs.com/studypanp/p/4890970.html 单元代码: (************************************ ...
- sping加载bean都发生了些什么
问题描述:使用@Autowired注入的类,没有实例化 //Controller @RequestMapping(value="/deepblue") @Controller pu ...
- golang处理signal
signal一般用来实现优雅重启,或者重新加载配置文件等操作. 废话不多说,上表格 动作 号码 信号 golang kill pid 15 SIGTERM terminated kill -9 pid ...
- 苹果应用商店逾千款iOS应用存安全漏洞
据国外网站Ibtimes报道,知名网络安全公司FireEye日前警告称,由于一款名为“JSPatch”.可帮助开发者修改应用程序的软件上存在安全漏洞,导致苹果应用商店内1000多款使用了该框架的iOS ...
- [Z] C#程序中设置全局代理(Global Proxy)
https://www.cnblogs.com/Javi/p/7274268.html 1. HttpWebRequest类的Proxy属性,只要设置了该属性就能够使用代理了,如下: 1 ...