C#实现基于Base64的加密解密类实例

所属分类: 软件编程 / C#教程 阅读数: 50
收藏 0 赞 0 分享

本文实例讲述了C#实现基于Base64的加密解密类。分享给大家供大家参考。具体如下:

这个C#类是一个基于Base64的加密和解密类,用户可以可以使用默认的秘钥进行加密、解密,也可以自己设定秘钥进行加密和解密,非常实用

using System;
using System.Security.Cryptography; 
using System.Text;
namespace DotNet.Utilities
{
 /// <summary>
 /// Encrypt 的摘要说明。
 /// </summary>
 public class DEncrypt
 {
  /// <summary>
  /// 构造方法
  /// </summary>
  public DEncrypt() 
  { 
  } 
  #region 使用 缺省密钥字符串 加密/解密string
  /// <summary>
  /// 使用缺省密钥字符串加密string
  /// </summary>
  /// <param name="original">明文</param>
  /// <returns>密文</returns>
  public static string Encrypt(string original)
  {
   return Encrypt(original,"sharejs.com");
  }
  /// <summary>
  /// 使用缺省密钥字符串解密string
  /// </summary>
  /// <param name="original">密文</param>
  /// <returns>明文</returns>
  public static string Decrypt(string original)
  {
   return Decrypt(original,"sharejs.com",System.Text.Encoding.Default);
  }
  #endregion
  #region 使用 给定密钥字符串 加密/解密string
  /// <summary>
  /// 使用给定密钥字符串加密string
  /// </summary>
  /// <param name="original">原始文字</param>
  /// <param name="key">密钥</param>
  /// <param name="encoding">字符编码方案</param>
  /// <returns>密文</returns>
  public static string Encrypt(string original, string key) 
  { 
   byte[] buff = System.Text.Encoding.Default.GetBytes(original); 
   byte[] kb = System.Text.Encoding.Default.GetBytes(key);
   return Convert.ToBase64String(Encrypt(buff,kb));   
  }
  /// <summary>
  /// 使用给定密钥字符串解密string
  /// </summary>
  /// <param name="original">密文</param>
  /// <param name="key">密钥</param>
  /// <returns>明文</returns>
  public static string Decrypt(string original, string key)
  {
   return Decrypt(original,key,System.Text.Encoding.Default);
  }
  /// <summary>
  /// 使用给定密钥字符串解密string,返回指定编码方式明文
  /// </summary>
  /// <param name="encrypted">密文</param>
  /// <param name="key">密钥</param>
  /// <param name="encoding">字符编码方案</param>
  /// <returns>明文</returns>
  public static string Decrypt(string encrypted, string key,Encoding encoding) 
  {    
   byte[] buff = Convert.FromBase64String(encrypted); 
   byte[] kb = System.Text.Encoding.Default.GetBytes(key);
   return encoding.GetString(Decrypt(buff,kb));   
  } 
  #endregion
  #region 使用 缺省密钥字符串 加密/解密/byte[]
  /// <summary>
  /// 使用缺省密钥字符串解密byte[]
  /// </summary>
  /// <param name="encrypted">密文</param>
  /// <param name="key">密钥</param>
  /// <returns>明文</returns>
  public static byte[] Decrypt(byte[] encrypted) 
  { 
   byte[] key = System.Text.Encoding.Default.GetBytes("sharejs.com"); 
   return Decrypt(encrypted,key);   
  }
  /// <summary>
  /// 使用缺省密钥字符串加密
  /// </summary>
  /// <param name="original">原始数据</param>
  /// <param name="key">密钥</param>
  /// <returns>密文</returns>
  public static byte[] Encrypt(byte[] original) 
  { 
   byte[] key = System.Text.Encoding.Default.GetBytes("sharejs.com"); 
   return Encrypt(original,key);   
  } 
  #endregion
  #region 使用 给定密钥 加密/解密/byte[]
  /// <summary>
  /// 生成MD5摘要
  /// </summary>
  /// <param name="original">数据源</param>
  /// <returns>摘要</returns>
  public static byte[] MakeMD5(byte[] original)
  {
   MD5CryptoServiceProvider hashmd5 = new MD5CryptoServiceProvider();  
   byte[] keyhash = hashmd5.ComputeHash(original);    
   hashmd5 = null; 
   return keyhash;
  }
  /// <summary>
  /// 使用给定密钥加密
  /// </summary>
  /// <param name="original">明文</param>
  /// <param name="key">密钥</param>
  /// <returns>密文</returns>
  public static byte[] Encrypt(byte[] original, byte[] key) 
  { 
   TripleDESCryptoServiceProvider des = new TripleDESCryptoServiceProvider();    
   des.Key = MakeMD5(key);
   des.Mode = CipherMode.ECB; 
   return des.CreateEncryptor().TransformFinalBlock(original, 0, original.Length);   
  } 
  /// <summary>
  /// 使用给定密钥解密数据
  /// </summary>
  /// <param name="encrypted">密文</param>
  /// <param name="key">密钥</param>
  /// <returns>明文</returns>
  public static byte[] Decrypt(byte[] encrypted, byte[] key) 
  { 
   TripleDESCryptoServiceProvider des = new TripleDESCryptoServiceProvider(); 
   des.Key = MakeMD5(key);  
   des.Mode = CipherMode.ECB; 
   return des.CreateDecryptor().TransformFinalBlock(encrypted, 0, encrypted.Length);
  } 
  #endregion
 }
}

希望本文所述对大家的C#程序设计有所帮助。

更多精彩内容其他人还在看

winform用datagridview制作课程表实例

这篇文章主要介绍了winform用datagridview制作课程表的方法,实例分析了WinForm实现课程表的结构、数据库及调用技巧,需要的朋友可以参考下
收藏 0 赞 0 分享

C#中winform控制textbox输入只能为数字的方法

这篇文章主要介绍了C#中winform控制textbox输入只能为数字的方法,包括使用keyPress事件限制键盘输入以及TextChanged事件限制粘贴等情况,来实现控制输入为数字的功能,需要的朋友可以参考下
收藏 0 赞 0 分享

C#省份城市下拉框联动简单实现方法

这篇文章主要介绍了C#省份城市下拉框联动简单实现方法,涉及字典的定义与索引的用法,是非常实用的技巧,需要的朋友可以参考下
收藏 0 赞 0 分享

C#处理MySql多个返回集的方法

这篇文章主要介绍了C#处理MySql多个返回集的方法,实现了对处理MySql多个返回集进行封装,是非常实用的技巧,需要的朋友可以参考下
收藏 0 赞 0 分享

C#无限参数的写法

这篇文章主要介绍了C#无限参数的写法,通过循环遍历再结合paras.Add方法实现无限参数的功能,是比较实用的技巧,需要的朋友可以参考下
收藏 0 赞 0 分享

C#反射应用实例

这篇文章主要介绍了C#反射应用,实例分析了通过反射实现多系统数据库的配置方法,是比较实用的技巧,需要的朋友可以参考下
收藏 0 赞 0 分享

C#窗体传值实例汇总

这篇文章主要介绍了C#窗体传值,实例形式汇总了静态变量传值、委托传值、对话框之间的传值等常见应用技巧,需要的朋友可以参考下
收藏 0 赞 0 分享

C#把数组中的某个元素取出来放到第一个位置的实现方法

这篇文章主要介绍了C#把数组中的某个元素取出来放到第一个位置的实现方法,涉及C#针对数组的常见操作技巧,非常具有实用价值,需要的朋友可以参考下
收藏 0 赞 0 分享

C#中Equality和Identity浅析

这篇文章主要介绍了C#中Equality和Identity浅析,本文先是讲解了Equality和Identity的定义,同时讲解了判断两个对象等价性的4种方法,需要的朋友可以参考下
收藏 0 赞 0 分享

在Linux上运行C#的方法

这篇文章主要介绍了在Linux上运行C#的方法,实例分析了Linux平台下Mono软件包的应用技巧,以及在此基础之上的C#运行方法,具有一定的参考借鉴价值,需要的朋友可以参考下
收藏 0 赞 0 分享
查看更多