C#一个封装的加密解密类

原创 2005年03月01日 08:31:00
using System;
using System.Text;
using System.Globalization;
using System.Security.Cryptography; 
using System.Windows.Forms;

namespace Jh.Encrypts
{
 public class JhEncrypt 
 { 
  /// <summary>
  /// 构造方法
  /// </summary>
  public JhEncrypt() 
  { 
  } 
  /// <summary>
  /// 使用缺省密钥字符串加密
  /// </summary>
  /// <param name="original">明文</param>
  /// <returns>密文</returns>
  public static string Encrypt(string original)
  {
   return Encrypt(original,"JASONHEUNG");
  }
  /// <summary>
  /// 使用缺省密钥解密
  /// </summary>
  /// <param name="original">密文</param>
  /// <returns>明文</returns>
  public static string Decrypt(string original)
  {
   return Decrypt(original,"JASONHEUNG",System.Text.Encoding.Default);
  }
  /// <summary>
  /// 使用给定密钥解密
  /// </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>
  /// 使用缺省密钥解密,返回指定编码方式明文
  /// </summary>
  /// <param name="original">密文</param>
  /// <param name="encoding">编码方式</param>
  /// <returns>明文</returns>
  public static string Decrypt(string original,Encoding encoding)
  {
   return Decrypt(original,"JASONHEUNG",encoding);
  }
  /// <summary>
  /// 使用给定密钥加密
  /// </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>
  /// 使用给定密钥解密
  /// </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));     
  } 
  /// <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);
  } 
 
  /// <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("JASONHEUNG");
   return Encrypt(original,key);    
  } 

  /// <summary>
  /// 使用缺省密钥解密数据
  /// </summary>
  /// <param name="encrypted">密文</param>
  /// <param name="key">密钥</param>
  /// <returns>明文</returns>
  public static byte[] Decrypt(byte[] encrypted) 
  { 
   byte[] key = System.Text.Encoding.Default.GetBytes("JASONHEUNG");
   return Decrypt(encrypted,key);    
  } 
 
 } 
}

C# 常见加密解密类

大部分的加密类的使用方式是差不多的,其中MD5和SHA类似,均为不可逆;RSA位可加可解;DES和AES类似,均需要加密向量;文中所有明文加密后都转为了净荷明文。没必要转Byte转16进制字符串(难为...
  • hotmee
  • hotmee
  • 2016年09月19日 11:14
  • 5033

C#一个封装的加密解密类

    using System;    using System.Text;    using System.Globalization;    using System.Security.Cryp...
  • lynnlin1122
  • lynnlin1122
  • 2008年04月18日 12:45
  • 609

一个C#封装的加密解密类代码

一起来看下代码,新手朋友多学习下!   using System;     using System.Text;     using System.Globalization;     using S...
  • hfzsjz
  • hfzsjz
  • 2008年12月24日 20:30
  • 647

C#一个封装的加密解密类

function StorePage(){d=document;t=d.selection?(d.selection.type!=None?d.selection.createRange().text...
  • lanwilliam
  • lanwilliam
  • 2008年06月06日 17:23
  • 532

C#使用MD5加密,DES加密解密的一个类

没什么好说的,直接上类。 using System; using System.IO; using System.Security.Cryptography; using System.Text; ...
  • xianglikai1
  • xianglikai1
  • 2017年02月05日 15:58
  • 1760

字符串加密解密类[封装][C#]

 using System;using System.Text;using System.Security.Cryptography;using System.IO;/**//// /// 字符串DE...
  • ikmb
  • ikmb
  • 2008年03月02日 09:12
  • 469

C# 导出 Excel 封装类 代码

using System; using System.Collections.Generic; using System.Linq; using System.Text;...
  • loglf
  • loglf
  • 2016年08月12日 00:11
  • 455

缓存技术,封装好的缓存类

using System; using System.Collections.Generic; using System.Linq; using System.Web; using EnYuan.BS...
  • lybwwp
  • lybwwp
  • 2014年01月14日 08:59
  • 3110

封装类之MYSQLHelper(C#连接MySql数据库)

using System; using System.Collections; using System.Configuration; using MySql.Data; using MySql.Da...
  • cxq_1993
  • cxq_1993
  • 2015年08月25日 08:57
  • 2185

C# 常用加密解密方法

字符串加密分可逆和不可逆加密两种,下面直接贴上代码 using System; using System.Collections.Generic; using System.Text; using...
  • zy332719794
  • zy332719794
  • 2014年12月03日 12:11
  • 3024
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:C#一个封装的加密解密类
举报原因:
原因补充:

(最多只允许输入30个字)