在.NET项目中,我们较多的使用到加密这个操作。因为在现代的项目中,对信息安全的要求越来越高,那么多信息的加密就变得至关重要。现在提供几种常用的加密/解密算法。

1.用于文本和Base64编码文本的互相转换 和 Byte[]和Base64编码文本的互相转换:

(1).将普通文本转换成Base64编码的文本

       /// <summary>
/// 将普通文本转换成Base64编码的文本
/// </summary>
/// <param name="value">普通文本</param>
/// <returns></returns>
public static string StringToBase64String(string value)
{
if (string.IsNullOrEmpty(value))
{
throw new ArgumentNullException(value);
}
try
{
var binBuffer = (new UnicodeEncoding()).GetBytes(value);
var base64ArraySize = (int)Math.Ceiling(binBuffer.Length / 3d) * ;
var charBuffer = new char[base64ArraySize];
Convert.ToBase64CharArray(binBuffer, , binBuffer.Length, charBuffer, );
var s = new string(charBuffer);
return s;
}
catch (Exception ex)
{
throw new Exception(ex.Message);
} }

(2).将Base64编码的文本转换成普通文本

        /// <summary>
/// 将Base64编码的文本转换成普通文本
/// </summary>
/// <param name="base64">Base64编码的文本</param>
/// <returns></returns>
public static string Base64StringToString(string base64)
{
if (string.IsNullOrEmpty(base64))
{
throw new ArgumentNullException(base64);
}
try
{
var charBuffer = base64.ToCharArray();
var bytes = Convert.FromBase64CharArray(charBuffer, , charBuffer.Length);
return (new UnicodeEncoding()).GetString(bytes);
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
}

(3).将Byte[]转换成Base64编码文本

        /// <summary>
/// 将Byte[]转换成Base64编码文本
/// </summary>
/// <param name="binBuffer">Byte[]</param>
/// <returns></returns>
public string ToBase64(byte[] binBuffer)
{
if (binBuffer == null)
{
throw new ArgumentNullException("binBuffer");
}
try
{
var base64ArraySize = (int)Math.Ceiling(binBuffer.Length / 3d) * ;
var charBuffer = new char[base64ArraySize];
Convert.ToBase64CharArray(binBuffer, , binBuffer.Length, charBuffer, );
var s = new string(charBuffer);
return s;
}
catch (Exception ex)
{
throw new Exception(ex.Message);
} }

(4).将Base64编码文本转换成Byte[]

       /// <summary>
/// 将Base64编码文本转换成Byte[]
/// </summary>
/// <param name="base64">Base64编码文本</param>
/// <returns></returns>
public byte[] Base64ToBytes(string base64)
{
if (string.IsNullOrEmpty(base64))
{
throw new ArgumentNullException(base64);
}
try
{
var charBuffer = base64.ToCharArray();
var bytes = Convert.FromBase64CharArray(charBuffer, , charBuffer.Length);
return bytes;
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
}

2. DES加密/解密类。

(1).加密

  private static readonly string KEY = "pengze0902";

        /// <summary>
/// 加密
/// </summary>
/// <param name="Text"></param>
/// <returns></returns>
public static string Encrypt(string Text)
{
return Encrypt(Text, KEY);
}
/// <summary>
/// 加密数据
/// </summary>
/// <param name="Text"></param>
/// <param name="sKey"></param>
/// <returns></returns>
public static string Encrypt(string Text, string sKey)
{
var des = new DESCryptoServiceProvider();
var inputByteArray = Encoding.Default.GetBytes(Text);
var bKey = Encoding.ASCII.GetBytes(Md5Hash(sKey).Substring(, ));
des.Key = bKey;
des.IV = bKey;
var ms = new System.IO.MemoryStream();
var cs = new CryptoStream(ms, des.CreateEncryptor(), CryptoStreamMode.Write);
cs.Write(inputByteArray, , inputByteArray.Length);
cs.FlushFinalBlock();
var ret = new StringBuilder();
foreach (byte b in ms.ToArray())
{
ret.AppendFormat("{0:X2}", b);
}
return ret.ToString();
}

(2).解密

   private static readonly string KEY = "pengze0902";
/// <summary>
/// 解密
/// </summary>
/// <param name="text"></param>
/// <returns></returns>
public static string Decrypt(string text)
{
return Decrypt(text, KEY);
} /// <summary>
/// 解密数据
/// </summary>
/// <param name="text"></param>
/// <param name="sKey"></param>
/// <returns></returns>
public static string Decrypt(string text, string sKey)
{
var des = new DESCryptoServiceProvider();
var len = text.Length / ;
byte[] inputByteArray = new byte[len];
int x;
for (x = ; x < len; x++)
{
var i = Convert.ToInt32(text.Substring(x * , ), );
inputByteArray[x] = (byte)i;
}
var bKey = Encoding.ASCII.GetBytes(Md5Hash(sKey).Substring(, ));
des.Key = bKey;
des.IV = bKey;
System.IO.MemoryStream ms = new System.IO.MemoryStream();
CryptoStream cs = new CryptoStream(ms, des.CreateDecryptor(), CryptoStreamMode.Write);
cs.Write(inputByteArray, , inputByteArray.Length);
cs.FlushFinalBlock();
return Encoding.Default.GetString(ms.ToArray());
}

(3).取得MD5加密串

        //// <summary>
/// 取得MD5加密串
/// </summary>
/// <param name="input">源明文字符串</param>
/// <returns>密文字符串</returns>
public static string Md5Hash(string input)
{
var md5 = new MD5CryptoServiceProvider();
var bs = Encoding.UTF8.GetBytes(input);
bs = md5.ComputeHash(bs);
var s = new StringBuilder();
foreach (var b in bs)
{
s.Append(b.ToString("x2").ToUpper());
}
var password = s.ToString();
return password;
}

3.MD5加密

(1). 32位大写

        /// <summary>
/// 32位大写
/// </summary>
/// <returns></returns>
public static string Upper32(string s)
{
var hashPasswordForStoringInConfigFile = System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(s, "md5");
if (hashPasswordForStoringInConfigFile != null)
s = hashPasswordForStoringInConfigFile.ToString();
return s.ToUpper();
}

(2). 32位小写

        /// <summary>
/// 32位小写
/// </summary>
/// <returns></returns>
public static string Lower32(string s)
{
var hashPasswordForStoringInConfigFile = System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(s, "md5");
if (hashPasswordForStoringInConfigFile != null)
s = hashPasswordForStoringInConfigFile.ToString();
return s.ToLower();
}

(3).16位大写

        /// <summary>
/// 16位大写
/// </summary>
/// <returns></returns>
public static string Upper16(string s)
{
var hashPasswordForStoringInConfigFile = System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(s, "md5");
if (hashPasswordForStoringInConfigFile != null)
s = hashPasswordForStoringInConfigFile.ToString();
return s.ToUpper().Substring(, );
}

(4).16位小写

        /// <summary>
/// 16位小写
/// </summary>
/// <returns></returns>
public static string Lower16(string s)
{
var hashPasswordForStoringInConfigFile = System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(s, "md5");
if (hashPasswordForStoringInConfigFile != null)
s = hashPasswordForStoringInConfigFile.ToString();
return s.ToLower().Substring(, );
}

4.Sha1签名算法

        /// <summary>
/// 签名算法
/// </summary>
/// <param name="str"></param>
/// <returns></returns>
public static string GetSha1(string str)
{
if (string.IsNullOrEmpty(str))
{
throw new ArgumentNullException(str);
}
try
{
//建立SHA1对象
SHA1 sha = new SHA1CryptoServiceProvider();
//将mystr转换成byte[]
var enc = new ASCIIEncoding();
var dataToHash = enc.GetBytes(str);
//Hash运算
var dataHashed = sha.ComputeHash(dataToHash);
//将运算结果转换成string
var hash = BitConverter.ToString(dataHashed).Replace("-", "");
return hash;
}
catch (Exception ex)
{
throw new Exception(ex.Message);
} }

5.Sha256加密算法

       /// <summary>
/// 将字符串转换为sha256散列
/// </summary>
/// <param name="data">字符串进行转换</param>
/// <returns>sha256散列或null</returns>
public static string ToSha256(this string data)
{
try
{
if (string.IsNullOrEmpty(data))
return null; var hashValue = new SHA256Managed().ComputeHash(Encoding.UTF8.GetBytes(data));
var hex = hashValue.Aggregate("", (current, x) => current + String.Format("{0:x2}", x)); if (string.IsNullOrEmpty(hex))
throw new Exception("Erro creating SHA256 hash"); return hex;
}
catch (Exception e)
{
throw new Exception(e.Message, e);
}
}

以上是一些较为常用的算法代码。

DotNet中几种常用的加密算法的更多相关文章

  1. Java中几种常用数据类型之间转换的方法

    Java中几种常用的数据类型之间转换方法: 1. short-->int 转换 exp: short shortvar=0; int intvar=0; shortvar= (short) in ...

  2. 【Android 界面效果28】Android应用中五种常用的menu

    Android Menu在手机的应用中起着导航的作用,作者总结了5种常用的Menu. 1.左右推出的Menu 前段时间比较流行,我最早是在海豚浏览器中看到的,当时耳目一新.最早使用左右推出菜单的,听说 ...

  3. C#中四种常用集合的运用(非常重要)

    C#中4个常用的集合 1.ArrayList ArrayList类似于数组,有人也称它为数组列表.ArrayList可以动态维护,而数组的容量是固定的. 它的索引会根据程序的扩展而重新进行分配和调整. ...

  4. Android中五种常用的menu

    Android Menu在手机的应用中起着导航的作用,作者总结了5种常用的Menu. 1.左右推出的Menu 前段时间比较流行,我最早是在海豚浏览器中看到的,当时耳目一新.最早使用左右推出菜单的,听说 ...

  5. java 中几种常用数据结构

    Java中有几种常用的数据结构,主要分为Collection和map两个主要接口(接口只提供方法,并不提供实现),而程序中最终使用的数据结构是继承自这些接口的数据结构类. 一.几个常用类的区别 1.A ...

  6. Android UI开发第二十九篇——Android中五种常用的menu(菜单)

    Android Menu在手机的应用中起着导航的作用,作者总结了5种常用的Menu. 1.左右推出的Menu 前段时间比较流行,我最早是在海豚浏览器中看到的,当时耳目一新.最早使用左右推出菜单的,听说 ...

  7. 二、python 中五种常用的数据类型

    一.字符串 单引号定义: str1 = 'hello' 双引号定义: str1 = "hello" 三引号定义:""" 人生苦短, 我用python! ...

  8. iOS中几种常用的数据存储方式

    自己稍微总结了一下下,方便大家查看 1.write直接写入文件的方法 永久保存在磁盘中,可以存储的对象有NSString.NSArray.NSDictionary.NSData.NSNumber,数据 ...

  9. 总结PHP中几种常用的网页跳转代码

    网页跳转的意思就是指当你在浏览器中访问A页面时,会自动跳转到B页面,往往网页跳转用在404页面中会比较多点.至于怎么实现网页跳转,网上已经提供了很多的方法,有些方法是不可行的,经过测试,叶德华今天就在 ...

随机推荐

  1. xss其他标签下的js用法总结大全

    前段时间我遇到一个问题,就是说普通的平台获取cookie的语句为↓           Default <script src=js地址></script> 1 <scr ...

  2. EditPlus快捷键

    Editplus 选中一行: ctrl+rEditplus 复制一行: ctrl+r选择行,然后ctrl+c复制.复制一行到下一行中:Editplus有:Ctrl+j 复制上一行的一个字符到当前行Ed ...

  3. Js函数的概念、作用、创建、调用!

    一.函数是用来帮助我们封装.调用代码的最方便的工具! 二.函数的创建方法有三种: 三.函数的创建方式有3种,调用方式也不是单一的,调用方式有4种!      1.作为一个函数去调用 函数名+();(函 ...

  4. CYQ.Data V5 数据库读写分离功能介绍

    前言 好多年没写关于此框架的新功能的介绍了,这些年一直在默默地更新,从Nuget上的记录就可以看出来: 这几天在看Java的一些东西,除了觉的Java和.NET的相似度实在太高之外,就是Java太原始 ...

  5. HTML5- Canvas入门(二)

    上篇文章我们了解了canvas的定义.获取和基础的绘图操作,其中的绘图功能我们讲解了线段绘制.上色.描边等方面知识点. 今天我们来讲讲矩形(Rectangle)和多边形的绘制. 矩形的绘制一共有两个口 ...

  6. 剑指Offer面试题:25.二叉搜索树与双向链表

    一.题目:二叉搜索树与双向链表 题目:输入一棵二叉搜索树,将该二叉搜索树转换成一个排序的双向链表.要求不能创建任何新的结点,只能调整树中结点指针的指向.比如输入下图中左边的二叉搜索树,则输出转换之后的 ...

  7. 作业六:团队项目——编写项目的Spec

    主要内容: 各组结合所选项目,编写项目的规格说明书(Spec),Spec应至少包含以下内容:(20分) 1. Spec的目标 2. 项目的典型用户和场景 3. 项目的用例模型 4. 项目中涉及到的术语 ...

  8. Morris.js和flot绘制折线图的比较

    [文章摘要] 最近用开源的AdminLTE做框架感觉效果特别好,其针对图表库Morris.js和flot都提供了不错的支持,也都提供了这两者的例子.不过Morris.js是基于Raphael.js来的 ...

  9. Express4 启航指南

    确实有感而发,Nodejs真的发展太快了,这么说的原因有两点:自己去年冬天买了本<了不起的Node.js>,里面介绍Express的版本还是2.x.x:前些天小伙伴买了本<Node. ...

  10. ASP.NET MVC 5 - 给电影表和模型添加新字段

    在本节中,您将使用Entity Framework Code First来实现模型类上的操作.从而使得这些操作和变更,可以应用到数据库中. 默认情况下,就像您在之前的教程中所作的那样,使用 Entit ...