• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >C#教程 > C#实现基于Base64的加密解密类实例

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

作者:feige 字体:[增加 减小] 来源:互联网 时间:2017-05-28

feige 通过本文主要向大家介绍了c#图片转base64,c#base64解码,c#base64,c#base64加密解密,c#base64加密等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

本文实例讲述了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
 }
}
</div>

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

</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • C#编写的Base64加密和解密类
  • C#对二进制数据进行base64编码的方法
  • C#解码base64编码二进制数据的方法
  • C#实现基于Base64的加密解密类实例

相关文章

  • 2017-05-28使用xmltextreader对象读取xml文档示例
  • 2017-05-28C#利用com操作excel释放进程的解决方法
  • 2017-05-28C#实现多线程下载文件的方法
  • 2017-05-28Chrome Visual Studio 2005下的编译过程
  • 2017-05-28C# 各种导出的方法总结
  • 2017-05-28简单了解C#设计模式编程中的桥接模式
  • 2017-05-28C#用ComboBox控件实现省与市的联动效果的方法
  • 2017-05-28C#中的预处理器指令详解
  • 2017-05-28C# 使用匿名函数解决EventHandler参数传递的难题
  • 2017-05-28详解C# Socket编程笔记

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • C#读取Excel并转化成XML的方法
    • C#控制Excel Sheet使其自适应页宽与列宽的方法
    • C# IFF图形结构解析代码
    • c#批量整理xml格式示例
    • C#(4.0)不常见的语法
    • C#中事件的定义和使用
    • C#模拟链表数据结构的实例解析
    • 初步认识C#中的Lambda表达式和匿名方法
    • C#默认双缓冲技术实例分析
    • C#开发教程之FTP上传下载功能详解

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有