您的位置 首页 > 数码极客

证明des加密算法是置换并说明des如何实现加脱密相似性.

3DES算法

3DES又称Triple DES,3DES是三重数据加密(TDEA,Triple Data Encryption Algorithm)块密码的通称,且可以逆推的一种算法方案。。它相当于是对每个数据块应用三次DES加密算法。密钥长度是128位,192位(bit),如果密码位数少于等于64位,加密结果与DES相同。原版DES容易被破解,新的3DES出现,增加了加密安全性,避免被暴力破解。到目前为止,仍没有人能破解3DES。

加密过程

3DES是DES向AES过渡的加密算法(1999年,NIST将3-DES指定为过渡的加密标准),其具体实现如下:设Ek()和Dk()代表DES算法的加密和解密过程,K代表DES算法使用的密钥,M代表明文,C代表密文,这样:

3DES加密过程为:C=Ek3(Dk2(Ek1(P)))

3DES解密过程为:P=Dk1(EK2(Dk3(C)))

具体的加/解密过程如下所示

using System;

using Sy;

using System. IO;

using Sy;

class Class1

{

static void Main()

{

Con(“Encrypt String…”);

txtKey = “tkGGRmBErvc=”;

btnKeyGen();

Con(“Encrypt Key :{0}”,txtKey);

txtIV = “Kl7ZgtM1dvQ=”;

btnIVGen();

Con(“Encrypt IV :{0}”,txtIV);

Con();

string txtEncrypted = EncryptString(“1111”);

Con(“Encrypt String : {0}”,txtEncrypted);

string txtOriginal = DecryptString(txtEncrypted);

Con(“Decrypt String : {0}”,txtOriginal);

}

private static SymmetricAlgorithm mCSP;

private static string txtKey;

private static string txtIV;

private static void btnKeyGen()

{

mCSP = SetEnc();

byte[] byt2 = Convert.FromString(txtKey);

mCSP.Key = byt2;

}

private static void btnIVGen()

{

byte[] byt2 = Convert.FromString(txtIV);

mCSP.IV = byt2;

}

private static string EncryptString(string Value)

{

ICryptoTransform ct;

MemoryStream ms;

CryptoStream cs;

byte[] byt;

ct = mCSP.CreateEncryptor, mCSP.IV);

byt = Encoding.UTF8.GetBytes(Value);

ms = new MemoryStream();

cs = new CryptoStream(ms, ct, Cry);

cs.Write(byt, 0, byt.Length);

cs.FlushFinalBlock();

cs.Close();

return Convert.ToString());

}

private static string DecryptString(string Value)

{

ICryptoTransform ct;

MemoryStream ms;

CryptoStream cs;

byte[] byt;

ct = mCSP.CreateDecryptor, mCSP.IV);

byt = Convert.FromString(Value);

ms = new MemoryStream();

cs = new CryptoStream(ms, ct, Cry);

cs.Write(byt, 0, byt.Length);

cs.FlushFinalBlock();

cs.Close();

return Encoding.UTF8.GetString());

}

private static SymmetricAlgorithm SetEnc()

{

return new DESCryptoServiceProvider();

}

}

K1、K2、K3决定了算法的安全性,若三个密钥互不相同,本质上就相当于用一个长为168位的密钥进行加密。多年来,它在对付强力攻击时是比较安全的。若数据对安全性要求不那么高,K1可以等于K3。在这种情况下,密钥的有效长度为112位。

——————————————

SSL证书是HTTP明文协议升级HTTPS加密协议的重要渠道,是网络安全传输的加密通道。关于更多SSL证书的资讯,请关注数安时代(GDCA)。GDCA致力于网络信息安全,已通过WebTrust 的国际认证,是全球可信任的证书签发机构。GDCA专业技术团队将根据用户具体情况为其提供最优的产品选择建议,并针对不同的应用或服务器要求提供专业对应的HTTPS解决方案。

文章来源于

责任编辑: 鲁达

1.内容基于多重复合算法人工智能语言模型创作,旨在以深度学习研究为目的传播信息知识,内容观点与本网站无关,反馈举报请
2.仅供读者参考,本网站未对该内容进行证实,对其原创性、真实性、完整性、及时性不作任何保证;
3.本站属于非营利性站点无毒无广告,请读者放心使用!

“证明des加密算法是置换并说明des如何实现加脱密相似性.”边界阅读