下面是编程之家 jb51.cc 通过网络收集整理的代码片段。
编程之家小编现在分享给大家,也给大家做个参考。
using System;
using System.Security.Cryptography;
using System.Text;
namespace DotNet.Utilities
{
///
/// Encrypt 的摘要说明。
///
public class DEncrypt
{
///
/// 构造方法
///
public DEncrypt()
{
}
#region 使用 缺省密钥字符串 加密/解密string
///
/// 使用缺省密钥字符串加密string
///
/// 明文
/// 密文
public static string Encrypt(string original)
{
return Encrypt(original,"sharejs.com");
}
///
/// 使用缺省密钥字符串解密string
///
/// 密文
/// 明文
public static string Decrypt(string original)
{
return Decrypt(original,"sharejs.com",System.Text.Encoding.Default);
}
#endregion
#region 使用 给定密钥字符串 加密/解密string
///
/// 使用给定密钥字符串加密string
///
/// 原始文字
/// 密钥
/// 字符编码方案
/// 密文
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));
}
///
/// 使用给定密钥字符串解密string
///
/// 密文
/// 密钥
/// 明文
public static string Decrypt(string original,string key)
{
return Decrypt(original,key,System.Text.Encoding.Default);
}
///
/// 使用给定密钥字符串解密string,返回指定编码方式明文
///
/// 密文
/// 密钥
/// 字符编码方案
/// 明文
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[]
///
/// 使用缺省密钥字符串解密byte[]
///
/// 密文
/// 密钥
/// 明文
public static byte[] Decrypt(byte[] encrypted)
{
byte[] key = System.Text.Encoding.Default.GetBytes("sharejs.com");
return Decrypt(encrypted,key);
}
///
/// 使用缺省密钥字符串加密
///
/// 原始数据
/// 密钥
/// 密文
public static byte[] Encrypt(byte[] original)
{
byte[] key = System.Text.Encoding.Default.GetBytes("sharejs.com");
return Encrypt(original,key);
}
#endregion
#region 使用 给定密钥 加密/解密/byte[]
///
/// 生成MD5摘要
///
/// 数据源
/// 摘要
public static byte[] MakeMD5(byte[] original)
{
MD5CryptoServiceProvider hashmd5 = new MD5CryptoServiceProvider();
byte[] keyhash = hashmd5.ComputeHash(original);
hashmd5 = null;
return keyhash;
}
///
/// 使用给定密钥加密
///
/// 明文
/// 密钥
/// 密文
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,original.Length);
}
///
/// 使用给定密钥解密数据
///
/// 密文
/// 密钥
/// 明文
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,encrypted.Length);
}
#endregion
}
}
以上是编程之家(jb51.cc)为你收集整理的全部代码内容,希望文章能够帮你解决所遇到的程序开发问题。
如果觉得编程之家网站内容还不错,欢迎将编程之家网站推荐给程序员好友。
相关文章
总结
如果觉得编程之家网站内容还不错,欢迎将编程之家网站推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您喜欢交流学习经验,点击链接加入交流1群:1065694478(已满)交流2群:163560250
本文介绍了如何使用C#进行基于Base64的加密,并使用Java进行解密,同时提供了相应的DEncrypt类实现。代码包括C#中使用TripleDES加密和解密的方法,以及与Java互操作的示例。
1万+

被折叠的 条评论
为什么被折叠?



