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

作者:feige 时间:2023-02-09 19:35:57 

本文实例讲述了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#程序设计有所帮助。

标签:C#,Base64,加密,解密,类
0
投稿

猜你喜欢

  • C#读取二进制文件方法分析

    2022-04-23 11:17:43
  • C#将PPT文件转换成PDF文件

    2022-09-08 20:33:21
  • lambda表达式解决java后台分组排序过程解析

    2023-11-29 06:03:39
  • Java中DataInputStream和DataOutputStream的使用方法

    2023-02-03 04:08:28
  • IDEA 使用mybatis插件Free Mybatis plugin的步骤(推荐)

    2022-12-05 02:01:03
  • Unity Shader实现径向模糊效果

    2021-09-06 01:02:47
  • springboot配置http跳转https的过程

    2021-12-25 07:31:11
  • Java协程编程之Loom项目实战记录

    2023-10-23 17:44:06
  • Spring Boot Actuator管理日志的实现

    2023-02-12 10:45:40
  • C#获取任务栏显示进程的方法

    2023-08-28 11:09:53
  • Android Hilt Retrofit Paging3使用实例

    2022-11-20 21:06:59
  • 解决mybatis三表连接查询数据重复的问题

    2023-09-13 15:24:25
  • SpringBoot之Controller的使用详解

    2023-02-16 21:18:30
  • Jsoup解析html实现招聘信息查询功能

    2022-01-08 19:38:07
  • C#使用GZipStream解压缩数据文件的方法

    2022-09-22 15:40:34
  • c#快速写本地日志方法

    2021-08-24 09:31:17
  • Java TreeMap排序算法实例

    2023-02-25 10:26:20
  • C#算法之各位相加

    2021-09-03 17:32:42
  • Android应用中图片浏览时实现自动切换功能的方法详解

    2023-04-13 15:34:00
  • Mybatis如何获取最新插入数据的id

    2023-02-26 08:15:20
  • asp之家 软件编程 m.aspxhome.com