C#加密算法总结

MD5加密

         /// <summary>
/// MD5加密
/// </summary>
/// <param name="strPwd">原字符串</param>
/// <returns>加密后字符串</returns>
public static string GetMD5(string strPwd)
{
//MD5 对象创建的两种方式
//MD5 md5 = MD5.Create();
MD5 md5 = new MD5CryptoServiceProvider();
//将输入的密码转换成字节数组
byte[] bPwd = Encoding.UTF8.GetBytes(strPwd);
//计算指定字节数组的哈希值
byte[] bMD5 = md5.ComputeHash(bPwd);
//释放加密服务提供类的所有资源
md5.Clear();
StringBuilder sbMD5Pwd = new StringBuilder();
for (int i = ; i < bMD5.Length; i++)
{
//将每个字节数据转换为2位的16进制的字符
sbMD5Pwd.Append(bMD5[i].ToString("x2"));
}
return sbMD5Pwd.ToString();
}

SHA1加密

         /// <summary>
/// 使用 SHA1 加密算法来加密
/// </summary>
/// <param name="sourceString">原字符串</param>
/// <returns>加密后字符串</returns>
public static string SHA1_Encrypt(string sourceString)
{
byte[] StrRes = Encoding.UTF8.GetBytes(sourceString);
HashAlgorithm iSHA = new SHA1CryptoServiceProvider();
StrRes = iSHA.ComputeHash(StrRes);
StringBuilder EnText = new StringBuilder();
foreach (byte iByte in StrRes)
{
EnText.AppendFormat("{0:x2}", iByte);
}
return EnText.ToString();
}

SHA256加密

         /// <summary>
/// SHA256 加密
/// </summary>
/// <param name="sourceString">原字符串</param>
/// <returns>加密后字符串</returns>
public static string SHA256_Encrypt(string sourceString)
{
byte[] data = Encoding.UTF8.GetBytes(sourceString);
SHA256 shaM = SHA256.Create();
byte[] result = shaM.ComputeHash(data);
StringBuilder EnText = new StringBuilder();
foreach (byte iByte in result)
{
EnText.AppendFormat("{0:x2}", iByte);
}
return EnText.ToString();
}

SHA384加密

         /// <summary>
/// SHA384 加密
/// </summary>
/// <param name="sourceString">原字符串</param>
/// <returns>加密后字符串</returns>
public static string SHA384_Encrypt(string sourceString)
{
byte[] data = Encoding.UTF8.GetBytes(sourceString);
SHA384 shaM = SHA384.Create();
byte[] result = shaM.ComputeHash(data);
StringBuilder EnText = new StringBuilder();
foreach (byte iByte in result)
{
EnText.AppendFormat("{0:x2}", iByte);
}
return EnText.ToString();
}

SHA512加密

         /// <summary>
/// SHA512_加密
/// </summary>
/// <param name="sourceString">原字符串</param>
/// <returns>加密后字符串</returns>
public static string SHA512_Encrypt(string sourceString)
{
byte[] data = Encoding.UTF8.GetBytes(sourceString);
SHA512 shaM = new SHA512Managed();
byte[] result = shaM.ComputeHash(data);
StringBuilder EnText = new StringBuilder();
foreach (byte iByte in result)
{
EnText.AppendFormat("{0:x2}", iByte);
}
return EnText.ToString();
}

AES加密、解密

         /// <summary>
/// AES加密
/// </summary>
/// <param name="encryptStr">加密字符串</param>
/// <param name="encryptKey">密钥</param>
/// <returns>密码</returns>
public static string AESEncrypt(string encryptStr, string encryptKey)
{
if (string.IsNullOrWhiteSpace(encryptStr))
return string.Empty; encryptKey = StringHelper.SubString(encryptKey, );
encryptKey = encryptKey.PadRight(, ' '); //分组加密算法
SymmetricAlgorithm des = Rijndael.Create();
byte[] inputByteArray = Encoding.UTF8.GetBytes(encryptStr);//得到需要加密的字节数组
//设置密钥及密钥向量
des.Key = Encoding.UTF8.GetBytes(encryptKey);
des.IV = _aeskeys;
byte[] cipherBytes = null;
using (MemoryStream ms = new MemoryStream())
{
using (CryptoStream cs = new CryptoStream(ms, des.CreateEncryptor(), CryptoStreamMode.Write))
{
cs.Write(inputByteArray, , inputByteArray.Length);
cs.FlushFinalBlock();
cipherBytes = ms.ToArray();//得到加密后的字节数组
cs.Close();
ms.Close();
}
}
return Convert.ToBase64String(cipherBytes);
} /// <summary>
/// AES解密
/// </summary>
/// <param name="decryptStr">解密字符串</param>
/// <param name="decryptKey">密钥</param>
/// <returns>原码</returns>
public static string AESDecrypt(string decryptStr, string decryptKey)
{
if (string.IsNullOrWhiteSpace(decryptStr))
return string.Empty; decryptKey = StringHelper.SubString(decryptKey, );
decryptKey = decryptKey.PadRight(, ' '); byte[] cipherText = Convert.FromBase64String(decryptStr); SymmetricAlgorithm des = Rijndael.Create();
des.Key = Encoding.UTF8.GetBytes(decryptKey);
des.IV = _aeskeys;
byte[] decryptBytes = new byte[cipherText.Length];
using (MemoryStream ms = new MemoryStream(cipherText))
{
using (CryptoStream cs = new CryptoStream(ms, des.CreateDecryptor(), CryptoStreamMode.Read))
{
cs.Read(decryptBytes, , decryptBytes.Length);
cs.Close();
ms.Close();
}
}
return Encoding.UTF8.GetString(decryptBytes).Replace("\0", "");//将字符串后尾的'\0'去掉
}

DES加密

  

         /// <summary>
/// DES加密字符串
/// </summary>
/// <param name="encryptString">待加密的字符串</param>
/// <param name="encryptKey">加密密钥,要求为8位</param>
/// <returns>加密成功返回加密后的字符串,失败返回源串</returns>
public string EncryptDES(string encryptString, string encryptKey)
{
try
{
byte[] rgbKey = Encoding.UTF8.GetBytes(encryptKey.Substring(, ));
byte[] rgbIV = Keys;
byte[] inputByteArray = Encoding.UTF8.GetBytes(encryptString);
DESCryptoServiceProvider dCSP = new DESCryptoServiceProvider();
MemoryStream mStream = new MemoryStream();
CryptoStream cStream = new CryptoStream(mStream, dCSP.CreateEncryptor(rgbKey, rgbIV), CryptoStreamMode.Write);
cStream.Write(inputByteArray, , inputByteArray.Length);
cStream.FlushFinalBlock();
return Convert.ToBase64String(mStream.ToArray());
}
catch
{
return encryptString;
}
} /// <summary>
/// DES解密字符串
/// </summary>
/// <param name="decryptString">待解密的字符串</param>
/// <param name="decryptKey">解密密钥,要求为8位,和加密密钥相同</param>
/// <returns>解密成功返回解密后的字符串,失败返源串</returns>
public string DecryptDES(string decryptString, string decryptKey)
{
try
{
byte[] rgbKey = Encoding.UTF8.GetBytes(decryptKey.Substring(, ));
byte[] rgbIV = Keys;
byte[] inputByteArray = Convert.FromBase64String(decryptString);
DESCryptoServiceProvider DCSP = new DESCryptoServiceProvider();
MemoryStream mStream = new MemoryStream();
CryptoStream cStream = new CryptoStream(mStream, DCSP.CreateDecryptor(rgbKey, rgbIV), CryptoStreamMode.Write);
cStream.Write(inputByteArray, , inputByteArray.Length);
cStream.FlushFinalBlock();
return Encoding.UTF8.GetString(mStream.ToArray());
}
catch
{
return decryptString;
}
}

加密方法封装代码:

 using System.IO;
using System.Security.Cryptography;
using System.Text; namespace EncryptTools
{
public class EncryptHelper
{
/// <summary>
/// 获取某个哈希算法对应下的哈希值
/// </summary>
/// <param name="sourceString">源字符串</param>
/// <param name="algorithm">哈希算法</param>
/// <returns>经过计算的哈希值</returns>
private static string GetHash(string sourceString, HashAlgorithm algorithm)
{
byte[] sourceBytes = Encoding.UTF8.GetBytes(sourceString);
byte[] result = algorithm.ComputeHash(sourceBytes);
algorithm.Clear();
StringBuilder sb = new StringBuilder();
for (int i = ; i < result.Length; i++)
{
sb.Append(result[i].ToString("X2"));
}
return sb.ToString();
} /// <summary>
/// 获取MD5值
/// </summary>
/// <param name="sourceString">源字符串</param>
/// <returns>MD5值</returns>
public static string GetMD5(string sourceString)
{
MD5CryptoServiceProvider md5 = new MD5CryptoServiceProvider();
return GetHash(sourceString, md5);
} /// <summary>
/// 获取SHA1值
/// </summary>
/// <param name="sourceString">源字符串</param>
/// <returns>SHA1值</returns>
public static string GetSHA1(string sourceString)
{
SHA1 sha1 = new SHA1CryptoServiceProvider();
return GetHash(sourceString, sha1);
} /// <summary>
/// 获取SHA256值
/// </summary>
/// <param name="sourceString">源字符串</param>
/// <returns>SHA256值</returns>
public static string GetSHA256(string sourceString)
{
SHA256 sha256 = SHA256.Create();
return GetHash(sourceString, sha256);
} /// <summary>
/// 获取SHA384值
/// </summary>
/// <param name="sourceString">源字符串</param>
/// <returns>SHA384值</returns>
public static string GetSHA384(string sourceString)
{
SHA384 sha384 = SHA384.Create();
return GetHash(sourceString, sha384);
} /// <summary>
/// 获取SHA512值
/// </summary>
/// <param name="sourceString">源字符串</param>
/// <returns>SHA512值</returns>
public static string GetSHA512(string sourceString)
{
SHA512 sha512 = SHA512.Create();
return GetHash(sourceString, sha512);
} public static string GetFileBase64String(string filePath)
{
using (FileStream fs = new FileStream(filePath, FileMode.Open, FileAccess.Read, FileShare.Read))
{
using (BinaryReader reader = new BinaryReader(fs))
{
try
{
return GetBase64String(reader.ReadBytes((int)fs.Length));
}
catch (System.Exception ex)
{
throw ex;
}
}
}
} public static string GetBase64String(string sourceString)
{
byte[] buffer = Encoding.UTF8.GetBytes(sourceString);
return GetBase64String(buffer);
} public static string GetBase64String(string sourceString, Encoding encoding)
{
byte[] buffer = encoding.GetBytes(sourceString);
return GetBase64String(buffer);
} public static string GetBase64String(byte[] sourceBytes)
{
string base64String = System.Convert.ToBase64String(sourceBytes);
return base64String;
}
}
}

C#加密算法总结的更多相关文章

  1. 理解加密算法(三)——创建CA机构,签发证书并开始TLS通信

    接理解加密算法(一)--加密算法分类.理解加密算法(二)--TLS/SSL 1 不安全的TCP通信 普通的TCP通信数据是明文传输的,所以存在数据泄露和被篡改的风险,我们可以写一段测试代码试验一下. ...

  2. 在.NET Core 里使用 BouncyCastle 的DES加密算法

    .NET Core上面的DES等加密算法要等到1.2 才支持,我们可是急需这个算法的支持,文章<使用 JavaScriptService 在.NET Core 里实现DES加密算法>需要用 ...

  3. 使用 JavaScriptService 在.NET Core 里实现DES加密算法

    文章<ASP.NET Core love JavaScript>和<跨平台的 NodeJS 组件解决 .NetCore 不支持 System.Drawing图形功能的若干问题> ...

  4. Android数据加密之异或加密算法

    前言: 这几天被公司临时拉到去做Android IM即时通信协议实现,大致看了下他们定的协议,由于之前没有参与,据说因服务器性能限制,只达成非明文传递,具体原因我不太清楚,不过这里用的加密方式是采用异 ...

  5. [C#] 简单的 Helper 封装 -- SecurityHelper 安全助手:封装加密算法(MD5、SHA、HMAC、DES、RSA)

    using System; using System.IO; using System.Security.Cryptography; using System.Text; namespace Wen. ...

  6. java单向加密算法小结(2)--MD5哈希算法

    上一篇文章整理了Base64算法的相关知识,严格来说,Base64只能算是一种编码方式而非加密算法,这一篇要说的MD5,其实也不算是加密算法,而是一种哈希算法,即将目标文本转化为固定长度,不可逆的字符 ...

  7. java单向加密算法小结(1)--Base64算法

    从这一篇起整理一下常见的加密算法以及在java中使用的demo,首先从最简单的开始. 简单了解 Base64严格来说并不是一种加密算法,而是一种编码/解码的实现方式. 我们都知道,数据在计算机网络之间 ...

  8. 显示本地openssl支持的加密算法

    参考页面: http://www.yuanjiaocheng.net/webapi/parameter-binding.html http://www.yuanjiaocheng.net/webapi ...

  9. .net(c#)版RSA加密算法,拿走不谢

    今天有同学对接一个支付平台,涉及到RSA的签名和验签.由于对方是java的sdk,翻成c#语言时,搞了半天也没搞定.网上搜的东西都是各种copy还不解决问题. 碰巧,我之前对接过连连银通的网银支付和代 ...

  10. 加密算法中BASE64、MD5、SHA、HMAC等之间的区别

    http://blog.csdn.net/lplj717/article/details/51828692 根据项目需要了解了一下几种加密算法(参考其他博客),内容简要介绍BASE64.MD5.SHA ...

随机推荐

  1. Android ListView OnItemLongClick和OnItemClick事件内部细节分享以及几个比较特别的属性

    本文转自 http://blog.sina.com.cn/s/blog_783ede030101bnm4.html 作者kiven 辞职3,4个月在家休息,本以为楼主要程序员逆袭,结果失败告终继续码农 ...

  2. MyBatis 入门

    什么是 MyBatis ? MyBatis 是支持定制化 SQL.存储过程以及高级映射的优秀的持久层框架.MyBatis 避免了几乎所有的 JDBC 代码和手工设置参数以及抽取结果集.MyBatis ...

  3. ef 更新导航属性

    总之,要让所有的东西,都被DbContext管理状态 1.查出来,改了,再提交 2.new 出来,attach,再改,再提交 以上两种都较好理解 3.new出来,改了,再attach,在改状态,再提交 ...

  4. 【转载】C/C++ 函数指针 总结

    转载自:http://blog.csdn.net/shihui512/article/details/9787125 什么是函数指针函数指针的声明函数指针的赋值函数指针的使用将函数作为其他函数的参数在 ...

  5. [python]闭包到底是什么鬼?

    这些东西是我在慕课网,廖雪峰大神的python课中学到的.自己写成笔记的形式分享给大家. 先来看一段代码: def f1(x): return x*x def new_fn(f): def fn(j) ...

  6. QCustomplot使用分享(三) 图

    一.可以实现的图 相对于其他绘制图表的第三方库来说,QCustomPlot算是比较轻量的,不仅仅能实现功能,而且二次开发比较容易.下面我们来具体说下他可以实现那些图 QCPGraph:折线图,Line ...

  7. GPUImage滤镜之自然饱和度

    自然饱和度”是图像整体的明亮程度,“饱和度”是图像颜色的鲜艳程度. “饱和度”与“色相/饱和度”命令中的“饱和度”选项效果相同,可以增加整个画面的“饱和度”,但如调节到较高数值,图像会产生色彩过饱和从 ...

  8. angularJs自定义服务

    在AngularJS中,系统内置的服务都是以$开头,所以我们的自定义服务尽量避免以$开头.自定义服务的方式有如下几种: 使用Module的provider方法 使用Module的factory方法 使 ...

  9. python下的orm基本操作(1)--Mysql下的CRUD简单操作(含源码DEMO)

    最近逐渐打算将工作的环境转移到ubuntu下,突然发现对于我来说,这ubuntu对于我这种上上网,收收邮件,写写博客,写写程序的时实在是太合适了,除了刚接触的时候会不怎么完全适应命令行及各种权限管理, ...

  10. 《构建之法》第8、9、10章读书笔记、读后感以及Sprint1总结

    第八章:需求分析 软件需求 人们(用户)的需求五花八门,作为一个软件团队要准确而全面地获取这些需求主要有以下四个步骤: 获取和引导需求.这一步骤也被叫做“需求捕捉”.软件团队需要为用户着想,设身处地, ...