C#开发中常⽤的加密解密⽅法
相信很多⼈在开发过程中经常会遇到需要对⼀些重要的信息进⾏加密处理,今天给⼤家分享我个⼈总结的⼀些加密算法:
常见的加密⽅式分为可逆和不可逆两种⽅式
可逆:RSA,AES,DES等
不可逆:常见的MD5,SHAD等
⼀、MD5消息摘要算法
我想这是⼤家都常听过的算法,可能也⽤的⽐较多。那么什么是MD5算法呢?MD5全称是message-digest algorithm 5,简单的说就是单向的加密,也就是说⽆法根据密⽂推导出明⽂。
MD5主要⽤途:
1、对⼀段信息⽣成信息摘要,该摘要对该信息具有唯⼀性,可以作为数字签名
2、⽤于验证⽂件的有效性(是否有丢失或损坏的数据)
3、对⽤户密码的加密
4、在哈希函数中计算散列值
从上边的主要⽤途中我们看到,由于算法的某些不可逆特征,在加密应⽤上有较好的安全性。通过使⽤MD5加密算法,我们输⼊⼀个任意长度的字节串,都会⽣成⼀个128位的整数。所以根据这⼀点MD5被⼴泛的⽤作密码加密。下⾯我就像⼤家演⽰⼀下怎样进⾏密码加密。
⾸先需要引⼊命名空间,先看⼀个⽐较简单的MD5加密的例⼦:
using System.Security;
using System.Security.Cryptography;
public string ToMD5(string strs)
{
MD5 md5 = new MD5CryptoServiceProvider();
byte[] bytes = Encoding.Default.GetBytes(strs);//将要加密的字符串转换为字节数组
byte[] encryptdata = md5.ComputeHash(bytes);//将字符串加密后也转换为字符数组
return Convert.ToBase64String(encryptdata);//将加密后的字节数组转换为加密字符串
}
这⾥我们需要注意的是,不论是在加密的过程中,加密前要将加密字符串转为字节数组,加密后也要⽣成密⽂的字节数据,然后再转化为密⽂。
下⾯是关于MD5加密的其他形式,可以根据需求编写你们⾃⼰需要的加密算法:
/// <summary>
/// 创建哈希字符串适⽤于任何 MD5 哈希函数(在任何平台)上创建 32 个字符的⼗六进制格式哈希字符串
/// </summary>字符串转数组编码方式
/// <param name="source"></param>
/// <returns></returns>
public static string Get32MD5One(string source)
{
using (System.Security.Cryptography.MD5 md5Hash = System.Security.Cryptography.MD5.Create())
{
byte[] data = md5Hash.ComputeHash(System.Text.Encoding.UTF8.GetBytes(source));
System.Text.StringBuilder sBuilder = new System.Text.StringBuilder();
for (int i = 0; i < data.Length; i++)
{
sBuilder.Append(data[i].ToString("x2"));
}
string hash = sBuilder.ToString();
return hash.ToUpper();
}
}
/// <summary>
/// 获取16位md5加密
/// </summary>
/// <param name="source"></param>
/// <returns></returns>
public static string Get16MD5One(string source)
{
using (System.Security.Cryptography.MD5 md5Hash = System.Security.Cryptography.MD5.Create())
{
byte[] data = md5Hash.ComputeHash(System.Text.Encoding.UTF8.GetBytes(source));
//转换成字符串,并取9到25位
string sBuilder = BitConverter.ToString(data, 4, 8);
//BitConverter转换出来的字符串会在每个字符中间产⽣⼀个分隔符,需要去除掉
sBuilder = sBuilder.Replace("-", "");
return sBuilder.ToString().ToUpper();
}
}
//// <summary>
/// </summary>
/
// <param name="strSource">需要加密的明⽂</param>
/// <returns>返回32位加密结果,该结果取32位加密结果的第9位到25位</returns>
public static string Get32MD5Two(string source)
{
System.Security.Cryptography.MD5 md5 = new System.Security.Cryptography.MD5CryptoServiceProvider();
//获取密⽂字节数组
byte[] bytResult = md5.ComputeHash(System.Text.Encoding.Default.GetBytes(source));
//转换成字符串,32位
string strResult = BitConverter.ToString(bytResult);
//BitConverter转换出来的字符串会在每个字符中间产⽣⼀个分隔符,需要去除掉
strResult = strResult.Replace("-", "");
return strResult.ToUpper();
}
//// <summary>
/// </summary>
/// <param name="strSource">需要加密的明⽂</param>
/// <returns>返回16位加密结果,该结果取32位加密结果的第9位到25位</returns>
public static string Get16MD5Two(string source)
{
System.Security.Cryptography.MD5 md5 = new System.Security.Cryptography.MD5CryptoServiceProvider();
//获取密⽂字节数组
byte[] bytResult = md5.ComputeHash(System.Text.Encoding.Default.GetBytes(source));
//转换成字符串,并取9到25位
string strResult = BitConverter.ToString(bytResult, 4, 8);
//BitConverter转换出来的字符串会在每个字符中间产⽣⼀个分隔符,需要去除掉
strResult = strResult.Replace("-", "");
return strResult.ToUpper();
}
⼆、DES加密
DES加密算法为密码体制中的对称密码体制,⼜被称为美国数据加密标准,是1972年美国IBM公司研制的对称密码体制加密算法。明⽂按64位进⾏分组,密钥长64位,密钥事实上是56位参与DES运算(第8、16、24、32、40、48、56、64位是校验位,使得每个密钥都有奇数个1)分组后的明⽂组和56位的密钥按位替代或交换的⽅法形成密⽂组的加密⽅法。
DES,全称Data Encryption Standard,是⼀种对称加密算法。由于其安全性⽐较⾼(有限时间内,没
有⼀种加密⽅法可以说是100%安全),很可能是最⼴泛的密钥系统(我们公司也在⽤,估计你们也有在⽤....),唯⼀⼀种⽅法可以破解该算法,那就是穷举法。
/// <summary>
/// DES加密
/// </summary>
/// <param name="data">加密数据</param>
/// <param name="key">8位字符的密钥字符串</param>
/// <param name="iv">8位字符的初始化向量字符串</param>
/// <returns></returns>
public static string DESEncrypt(string data, string key, string iv)
{
byte[] byKey = System.Text.ASCIIEncoding.ASCII.GetBytes(key);
byte[] byIV = System.Text.ASCIIEncoding.ASCII.GetBytes(iv);
DESCryptoServiceProvider cryptoProvider = new DESCryptoServiceProvider();
int i = cryptoProvider.KeySize;
MemoryStream ms = new MemoryStream();
CryptoStream cst = new CryptoStream(ms, cryptoProvider.CreateEncryptor(byKey, byIV), CryptoStreamMode.Write);
StreamWriter sw = new StreamWriter(cst);
sw.Write(data);
sw.Flush();
cst.FlushFinalBlock();
sw.Flush();
return Convert.ToBase64String(ms.GetBuffer(), 0, (int)ms.Length);
}
/// <summary>
/// DES解密
/// </summary>
/// <param name="data">解密数据</param>
/// <param name="key">8位字符的密钥字符串(需要和加密时相同)</param>
/// <param name="iv">8位字符的初始化向量字符串(需要和加密时相同)</param>
/// <returns></returns>
public static string DESDecrypt(string data, string key, string iv)
{
byte[] byKey = System.Text.ASCIIEncoding.ASCII.GetBytes(key);
byte[] byIV = System.Text.ASCIIEncoding.ASCII.GetBytes(iv);
byte[] byEnc;
try
{
byEnc = Convert.FromBase64String(data);
}
catch
{
return null;
}
DESCryptoServiceProvider cryptoProvider = new DESCryptoServiceProvider();
MemoryStream ms = new MemoryStream(byEnc);
CryptoStream cst = new CryptoStream(ms, cryptoProvider.CreateDecryptor(byKey, byIV), CryptoStreamMode.Read);
StreamReader sr = new StreamReader(cst);
return sr.ReadToEnd();
}
此外还有AES加密算法,但是AES加密是⼀个新的可以⽤于保护电⼦数据的加密算法。其产⽣的密码是迭代对称的分组密码,代加密使⽤⼀个循环结构,在该循环中重复置换和替换输⼊数据。
三、RSA加密算法
在谈RSA加密算法之前,我们需要先了解下两个专业名词,对称加密和⾮对称加密。
对称加密即:含有⼀个称为密钥的东西,在消息发送前使⽤密钥对消息进⾏加密,在对⽅收到消息之后,使⽤相同的密钥进⾏解密
⾮对称加密即:加密和解密使⽤不同的密钥的⼀类加密算法。这类加密算法通常有两个密钥A和B,使⽤密钥A加密数据得到的密⽂,只有密钥B可以进⾏解密操作(即使密钥A也⽆法解密),相反,使⽤了密钥B加密数据得到的密⽂,只有密钥A可以解密。这两个密钥分别称为私钥和公钥,顾名思义,私钥就是你个⼈保留,不能公开的密钥,⽽公钥则是公开给加解密操作的另⼀⽅的。根据不同⽤途,对数据进⾏加密所使⽤的密钥也不相同(有时⽤公钥加密,私钥解密;有时相反⽤私钥加密,公钥解密)。⾮对称加密的代表算法是RSA算法。
了解了这两个名词下⾯来讲,RSA加密算法。RSA取名来⾃开发他们三者的名字。RSA是⽬前最有影响⼒的公钥加密算法,多⽤于数据加密和数字签名。虽然有这么⼤的影响⼒,但是同时它也有⼀些弊端,它产⽣密钥很⿇烦,受到素数产⽣技术的限制,因⽽难以做到⼀次⼀密,分组长度太⼤等。
下⾯通过⽰例演⽰使⽤RSA加密、解密,引⽤名称空间System.Security.Cryptography;
/// <summary>
/// RSA加密数据
/// </summary>
/// <param name="express">要加密数据</param>
/// <param name="KeyContainerName">密匙容器的名称</param>
/// <returns></returns>
public static string RSAEncryption(string express, string KeyContainerName = null)
{
System.Security.Cryptography.CspParameters param = new System.Security.Cryptography.CspParameters();
param.KeyContainerName = KeyContainerName ?? "zhiqiang"; //密匙容器的名称,保持加密解密⼀致才能解密成功
using (System.Security.Cryptography.RSACryptoServiceProvider rsa = new System.Security.Cryptography.RSACryptoServiceProvider(param))
{
byte[] plaindata = System.Text.Encoding.Default.GetBytes(express);//将要加密的字符串转换为字节数组
byte[] encryptdata = rsa.Encrypt(plaindata, false);//将加密后的字节数据转换为新的加密字节数组
return Convert.ToBase64String(encryptdata);//将加密后的字节数组转换为字符串
}
}
/// <summary>
/// RSA解密数据
/// </summary>
/// <param name="express">要解密数据</param>
/// <param name="KeyContainerName">密匙容器的名称</param>
/// <returns></returns>
public static string RSADecrypt(string ciphertext, string KeyContainerName = null)
{
System.Security.Cryptography.CspParameters param = new System.Security.Cryptography.CspParameters();
param.KeyContainerName = KeyContainerName ?? "zhiqiang"; //密匙容器的名称,保持加密解密⼀致才能解密成功
using (System.Security.Cryptography.RSACryptoServiceProvider rsa = new System.Security.Cryptography.RSACryptoServiceProvider(param))
{
byte[] encryptdata = Convert.FromBase64String(ciphertext);
byte[] decryptdata = rsa.Decrypt(encryptdata, false);
return System.Text.Encoding.Default.GetString(decryptdata);
}
}
四、Base64编码
这个就不做过多解释了,直接上代码。
#region Base64加密解密
/// <summary>
/// Base64加密
/// </summary>
/// <param name="input">需要加密的字符串</param>
/// <returns></returns>
public static string Base64Encrypt(string input)
{
return Base64Encrypt(input, new UTF8Encoding());
}
/// <summary>
/// Base64加密
/// </summary>
/// <param name="input">需要加密的字符串</param>
/// <param name="encode">字符编码</param>
/// <returns></returns>
public static string Base64Encrypt(string input, Encoding encode)
{
return Convert.ToBase64String(encode.GetBytes(input));
}
/// <summary>
/// Base64解密
/// </summary>
/// <param name="input">需要解密的字符串</param>
/// <returns></returns>
public static string Base64Decrypt(string input)
{
return Base64Decrypt(input, new UTF8Encoding());
}
/// <summary>
/
// Base64解密
/// </summary>
/// <param name="input">需要解密的字符串</param>
/// <param name="encode">字符的编码</param>
/// <returns></returns>
public static string Base64Decrypt(string input, Encoding encode)
{
return encode.GetString(Convert.FromBase64String(input));
}
#endregion
五、SHA安全散列算法
SHA,全称SecureHashAlgorithm,是⼀种数据加密算法,该算法的思想是接收⼀段明⽂,然后以⼀种不可逆的⽅式将它转换成⼀段(通常更⼩)密⽂,也可以简单的理解为取⼀串输⼊码(称为预映射或信息),并把它们转化为长度较短、位数固定的输出序列即散列值(也称为信息摘要或信息认证代码)的过程。
下⾯贴SHA各种加密算法代码:
//SHA为不可逆加密⽅式
public static string SHA1Encrypt(string Txt)
{
var bytes = System.Text.Encoding.Default.GetBytes(Txt);
var SHA = new System.Security.Cryptography.SHA1CryptoServiceProvider();
var encryptbytes = SHA.ComputeHash(bytes);
return Convert.ToBase64String(encryptbytes);
}
public static string SHA256Encrypt(string Txt)
{
var bytes = System.Text.Encoding.Default.GetBytes(Txt);
var SHA256 = new System.Security.Cryptography.SHA256CryptoServiceProvider();
var encryptbytes = SHA256.ComputeHash(bytes);
return Convert.ToBase64String(encryptbytes);
}
public static string SHA384Encrypt(string Txt)
{
var bytes = System.Text.Encoding.Default.GetBytes(Txt);
var SHA384 = new System.Security.Cryptography.SHA384CryptoServiceProvider();
var encryptbytes = SHA384.ComputeHash(bytes);
return Convert.ToBase64String(encryptbytes);
}
public string SHA512Encrypt(string Txt)
{
var bytes = System.Text.Encoding.Default.GetBytes(Txt);
var SHA512 = new System.Security.Cryptography.SHA512CryptoServiceProvider();
var encryptbytes = SHA512.ComputeHash(bytes);
return Convert.ToBase64String(encryptbytes);
}
六、AES加密算法
AES算法基于排列和置换运算。排列是对数据重新进⾏安排,置换是将⼀个数据单元替换为另⼀个。
AES 使⽤⼏种不同的⽅法来执⾏排列和置换运算。 AES是⼀个迭代的、对称密钥分组的密码,它可以使⽤128、192 和 256 位密钥,并且⽤ 128 位(16字节)分组加密和解密数据。与公共密钥密码使⽤密钥对不同,对称密钥密码使⽤相同的密钥加密和解密数据。通过分组密码返回的加密数据的位数与输⼊数据相同。迭代加密使⽤⼀个循环结构,在该循环中重复置换和替换输⼊数据。
/// <summary>
/// AES 加密
/// </summary>
/// <param name="str">明⽂(待加密)</param>
/// <param name="key">密⽂</param>
/// <returns></returns>
public string AesEncrypt(string str, string key)
{
if (string.IsNullOrEmpty(str)) return null;
Byte[] toEncryptArray = Encoding.UTF8.GetBytes(str);
RijndaelManaged rm = new RijndaelManaged
{
Key = Encoding.UTF8.GetBytes(key),
Mode = CipherMode.ECB,
Padding = PaddingMode.PKCS7
};
ICryptoTransform cTransform = rm.CreateEncryptor();
Byte[] resultArray = cTransform.TransformFinalBlock(toEncryptArray, 0, toEncryptArray.Length);
return Convert.ToBase64String(resultArray);
}
/// <summary>
/// AES 解密
/// </summary>
/// <param name="str">明⽂(待解密)</param>
/// <param name="key">密⽂</param>
/// <returns></returns>
public string AesDecrypt(string str, string key)
{
if (string.IsNullOrEmpty(str)) return null;
Byte[] toEncryptArray = Convert.FromBase64String(str);
RijndaelManaged rm = new RijndaelManaged
{
Key = Encoding.UTF8.GetBytes(key),
Mode = CipherMode.ECB,
Padding = PaddingMode.PKCS7
};
ICryptoTransform cTransform = rm.CreateDecryptor();
Byte[] resultArray = cTransform.TransformFinalBlock(toEncryptArray, 0, toEncryptArray.Length);
return Encoding.UTF8.GetString(resultArray);
}
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论