一个可逆的DES和TripleDES方式加密类(downmoon原创)
using
System;
using
System.Security;
using
System.Security.Cryptography;
using
System.IO;
using
System.Text;
namespace
EncryptDownmoon
...
{
/**/
///
<summary>
///
EncryptSqlConn的摘要说明。
///
</summary>
public
class
EncryptSqlConn
...
{
public
EncryptSqlConn()
...
{
if
(mCSP
==
null
)
...
{
mCSP
=
SetEnc();
}
}
/**/
///
<summary>
///
设置加密方式,0为DES,1为TripleDES
///
</summary>
///
<returns></returns>
public
EncryptSqlConn(
int
EnMethod)
...
{
if
(EnMethod
==
0
)
...
{
lngEnMethod
=
0
;
}
else
...
{
lngEnMethod
=
1
;
}
if
(mCSP
==
null
)
...
{
mCSP
=
SetEnc();
}
}
方法
#region
方法
private
SymmetricAlgorithmmCSP;
private
int
m_lngEnMethod
=
0
;
/**/
///
<summary>
///
加密方式,0为DES,1为TripleDES
///
</summary>
public
int
lngEnMethod
...
{
get
...
{
return
m_lngEnMethod;
}
set
...
{
m_lngEnMethod
=
value;
}
}
private
SymmetricAlgorithmSetEnc()
...
{
if
(lngEnMethod
==
0
)
...
{
return
new
DESCryptoServiceProvider();
}
else
return
new
TripleDESCryptoServiceProvider();
}
//
测试键值
private
string
genKeyValue
...
{
get
...
{
mCSP.GenerateKey();
return
Convert.ToBase64String(mCSP.Key);
}
}
//
测试IV值
private
string
genIVValue
...
{
get
...
{
mCSP.GenerateIV();
return
Convert.ToBase64String(mCSP.IV);
}
}
/**/
///
<summary>
///
加密字串
///
</summary>
///
<paramname="Value"></param>
///
<returns></returns>
public
string
EncryptString(
string
Value)
...
{
ICryptoTransformct;
MemoryStreamms;
CryptoStreamcs;
byte
[]byt;
ct
=
mCSP.CreateEncryptor(mCSP.Key,mCSP.IV);
//
ct=mCSP.CreateEncryptor(genKeyValue,genIVValue);
byt
=
Encoding.UTF8.GetBytes(Value);
ms
=
new
MemoryStream();
cs
=
new
CryptoStream(ms,ct,CryptoStreamMode.Write);
cs.Write(byt,
0
,byt.Length);
cs.FlushFinalBlock();
cs.Close();
return
Convert.ToBase64String(ms.ToArray());
}
/**/
///
<summary>
///
解密字串
///
</summary>
///
<paramname="Value"></param>
///
<returns></returns>
public
string
DecryptString(
string
Value)
...
{
ICryptoTransformct;
MemoryStreamms;
CryptoStreamcs;
byte
[]byt;
ct
=
mCSP.CreateDecryptor(mCSP.Key,mCSP.IV);
//
ct=mCSP.CreateDecryptor(genKeyValue,genIVValue);
byt
=
Convert.FromBase64String(Value);
ms
=
new
MemoryStream();
cs
=
new
CryptoStream(ms,ct,CryptoStreamMode.Write);
cs.Write(byt,
0
,byt.Length);
cs.FlushFinalBlock();
cs.Close();
return
Encoding.UTF8.GetString(ms.ToArray());
}
#endregion
}
}
分享到:
相关推荐
对称加密,作为一种传统而广泛使用的加密方法,其特点是加密和解密过程中使用同一个密钥。这意味着在信息传输过程中,发送方和接收方必须共享同一把密钥才能完成信息的加解密操作。因此,确保密钥的安全传递成为了...
TripleDES加密解密算法的实现(JAVA)
标题中的"TripleDES.zip_DES tripledes_TripleDES java_Tripledes java"表明这是一个关于Java编程中实现三重DES(Triple DES)加密算法的压缩文件。在这个压缩包中,我们主要会探讨DES(Data Encryption Standard)...
总结来说,这个“Qt写的DES加密算法展示程序”是一个学习和实践密码学的好例子,它结合了经典的DES加密算法和现代的Qt开发框架。对于希望了解这两方面的开发者,这是一个很好的起点,可以从中探索数据安全和GUI编程...
3DES(即Triple DES)是DES向AES过渡的加密算法,它使用3条64位的密钥对数据进行三次加密。是DES的一个更安全的变形。它以DES为基本模块,通过组合分组方法设计出分组加密算法。比起最初的DES,3DES更为安全。
标题中的"TripleDES.rar_DES CSharp_des_triple_triple DES_triple d"指的是一个关于Triple DES加密解密技术的C#实现。Triple DES(3DES)是数据加密标准(DES)的一种加强版本,用于提高DES的安全性。在这个压缩包...
这段代码中,`encrypt3DES`函数接收一个消息和一个密钥作为参数,使用提供的密钥和初始向量(IV)进行3DES加密,并将结果转换为Base64编码的字符串,便于在网络中传输。 在Java后端,我们可以使用Java的JCE(Java ...
1. **密钥扩展(Key Expansion)**:3DES需要三个56位的密钥,但通常用户只会提供一个,因此需要将这一个密钥扩展为三个不同的密钥,这可以通过简单的位操作实现。 2. **数据预处理(Data Preparation)**:对输入...
在提供的压缩包`Java TripleDES`中,很可能包含了实现3DES加密和解密功能的Java源代码,可能包括一个简单的示例或者完整的GUI应用程序,供开发者学习和使用。这些代码可以帮助理解3DES的工作原理,并且可以直接在...
以下是一个简单的3DES加密和解密示例: ```javascript // 引入crypto-js库 const CryptoJS = require("crypto-js"); // 定义3DES密钥 const key = CryptoJS.lib.WordArray.create([...]); // 加密函数 function ...
标题"TripleDES.rar_TripleDES_java TripleDES_triple DES_triple DES in"提及的核心是“TripleDES”,这是一个加密算法,它在Java编程环境中被实现。描述简单明了,表明这是一个使用TripleDES算法的程序。 **...
本资源包含了一个C#语言实现的3DES加密源码,可用于数据加密。 3DES的工作原理是通过三次应用DES算法来提高安全性。基本流程如下: 1. **初始阶段**:3DES使用一个16字节(即128位)的密钥,这个密钥被分为三个子...
TripleDES由于其算法特性,是一个可逆的加密方法。然而,尽管比DES更安全,TripleDES在现代密码学标准中已不再被视为最安全的选择,因为它相对较慢且112位的密钥长度在面对现代计算能力时可能不够强大。现在,更推荐...
1. **初始加密**:使用第一个密钥(Key1)进行DES加密。 2. **中间解密**:使用第二个密钥(Key2)对上一步得到的结果进行DES解密。 3. **最终加密**:再使用第三个密钥(Key3)对中间解密后的结果进行DES加密。 ...
本篇将详细介绍一个基于TripleDES(三重数据加密标准)的文件加密系统,该系统能够对文本文件、图像文件以及压缩文件进行加密,确保数据的安全性。 **TripleDES概述** TripleDES,全称为3DES或TDEA(Triple Data ...
3DES实际上是将一个DES加密过程重复三次,分为三个阶段:E1-D2-E3。其中E代表加密操作,D代表解密操作。在加密过程中,原始数据先用一个密钥进行加密,然后用第二个密钥进行解密,最后再用第三个密钥进行加密。解密...
本程序是本人综合一些加密解密算法,写成的加密解密算法类 其中包括对字符串加密解密、文件加密解密 加密方法有:DES,RC2,Rijndael,TripleDES,C#与java默认的DES加密算 法接口,MD5加密算法 vs2008 C# 源码
C#常用加密类包含DES、MD5、RC2、Rijndael、RSA、TripleDES
DES是一种对称加密算法,它的基本思想是将明文数据通过一个密钥转换成密文,然后在接收方使用相同的密钥将密文还原为明文。这个过程确保了只有拥有正确密钥的发送方和接收方才能读取信息,从而增强了数据的安全性。...