产品资料搜索:

最新产品展示

  • LDM8035接触式模块
    接触式IC卡读写模块 支持SLE4442/4428 小型化 低功耗 方便使用
  • LDM522-MINI射频模块
    体积小(1.9cm*1.4cm) ISO14443-A以及Mifare, Ultrlight&EV1等的低功耗模块
  • LDM-A3射频读卡器
    支持ISO14443A/B 二代证ID 低功耗 免驱
  • LDM523射频读卡模块
    支持iso14443A/B 韦根接口 二代证ID
  • 3DES的C语言实现

    2009-4-16

    3DES(即Triple DES)是DES向AES过渡的加密算法,它使用3条64位的密钥对数据进行三次加密。是DES的一个更安全的变形。它以DES为基本模块,通过组合分组方法密算法。比起最初的DES,3DES更为安全


     

     

    3DES-算法介绍


    设Ek()和Dk()代表DES算法的加密和解密过程,K代表DES算法使用的密钥,P代表明文,C代表密表,这样,

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

    具体的加/解密过程如下所示。
    using System; 
    using System.Text; 
    using System.IO; 
    using System.Security.Cryptography; 
    class Class1 

    static void Main() 

    Console.WriteLine("Encrypt String..."); 
    txtKey = "tkGGRmBErvc="; 
    btnKeyGen(); 
    Console.WriteLine("Encrypt Key :",txtKey); 
    txtIV = "Kl7ZgtM1dvQ="; 
    btnIVGen(); 
    Console.WriteLine("Encrypt IV :",txtIV); 
    Console.WriteLine(); 
    string txtEncrypted = EncryptString("1111"); 
    Console.WriteLine("Encrypt String : ",txtEncrypted); 
    string txtOriginal = DecryptString(txtEncrypted); 
    Console.WriteLine("Decrypt String : ",txtOriginal); 

    private static SymmetricAlgorithm mCSP; 
    private static string txtKey; 
    private static string txtIV; 
    private static void btnKeyGen() 

    mCSP = SetEnc(); 
    byte[] byt2 = Convert.FromBase64String(txtKey); 
    mCSP.Key = byt2; 

    private static void btnIVGen() 

    byte[] byt2 = Convert.FromBase64String(txtIV); 
    mCSP.IV = byt2; 

    private static string EncryptString(string Value) 

    ICryptoTransform ct; 
    MemoryStream ms; 
    CryptoStream cs; 
    byte[] byt; 
    ct = mCSP.CreateEncryptor(mCSP.Key, mCSP.IV); 
    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()); 

    private static string DecryptString(string Value) 

    ICryptoTransform ct; 
    MemoryStream ms; 
    CryptoStream cs; 
    byte[] byt; 
    ct = mCSP.CreateDecryptor(mCSP.Key, mCSP.IV); 
    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()); 

    private static SymmetricAlgorithm SetEnc() 

    return new DESCryptoServiceProvider(); 


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

    3DES-3DES算法


    3DES算法是指使用双长度(16字节)密钥K=(KL||KR)将8字节明文数据块进行3次DES加密/解密。如下所示: 
          Y = DES(KL)[DES-1(KR)[DES(KL[X])]] 
          解密方式为: 
          X = DES-1 (KL)[DES      (KR)[ DES-1 (KL[Y])]] 
      其中,DES(KL[X])表示用密钥K对数据X进行DES加密,DES-1 (KL[Y])表示用密钥K对数据Y进行解密。 
      SessionKey的计算采用3DES算法,计算出单倍长度的密钥。表示法为:SK = Session(DK,DATA) 
      3DES加密算法为: 
          VOID 3DES(BYTE DoubleKeyStr[16], BYTE Data[8], BYTE Out[8]) 

          BYTE Buf1[8], Buf2[8]; 
          DES      (&DoubleKeyStr[0], Data, Buf1); 
          UDES(&DoubleKeyStr[8], Buf1, Buf2); 
          DES      (&DoubleKeyStr[0], Buf2, Out); 
    }


    C实现的3DES加密算法下载

     

     

     

     

    © 2014 龙达科技有限公司版权所有,所有内容未经许可严禁复制