亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

C# 3DES加密詳解

 更新時間:2015年06月09日 11:20:52   投稿:hebedich  
3Des對每個數(shù)據(jù)塊進(jìn)行了三次的DES加密算法,是DES的一個更安全的變形。比起最初的DES,3DES更為安全。下面我們來看下在C#中的3DES加密方式的使用

最近一個項目中,因為服務(wù)端是用的java開發(fā)的,客戶端是用的C#,由于通信部分采用到了3DES加密,所以做個記錄,以備以后需要的時候直接用。

  這是對方(java)的加密算法,和網(wǎng)上流傳的代碼也差不多(主密鑰直接寫死了,方便測試)

package org.zwork.market.mina.msg;
import java.security.spec.KeySpec;
import javax.crypto.Cipher;
import javax.crypto.SecretKey;
import javax.crypto.SecretKeyFactory;
import javax.crypto.spec.DESKeySpec;
import javax.crypto.spec.DESedeKeySpec;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.zwork.market.MktContants;
public class ThreeEncryptDecrypt {
  private static final Logger LOGGER = LoggerFactory.getLogger(ThreeEncryptDecrypt.class);
  // 定義 加密算法,可用 DES,DESede,Blowfish
  public static final String Algorithm = "DESede";
  public static String DES = "DES/ECB/NoPadding";
  public static String TriDes = "DESede/ECB/NoPadding";
  // des加密
  public static byte[] des_crypt(byte key[], byte data[]) {
    try {
      KeySpec ks = new DESKeySpec(key);
      SecretKeyFactory kf = SecretKeyFactory.getInstance("DES");
      SecretKey ky = kf.generateSecret(ks);
      Cipher c = Cipher.getInstance(DES);
      c.init(Cipher.ENCRYPT_MODE, ky);
      return c.doFinal(data);
    } catch (Exception e) {
      LOGGER.error("des_crypt error:", e);
      return null;
    }
  }
  // des解密
  public static byte[] des_decrypt(byte key[], byte data[]) {
    try {
      KeySpec ks = new DESKeySpec(key);
      SecretKeyFactory kf = SecretKeyFactory.getInstance("DES");
      SecretKey ky = kf.generateSecret(ks);
      Cipher c = Cipher.getInstance(DES);
      c.init(Cipher.DECRYPT_MODE, ky);
      return c.doFinal(data);
    } catch (Exception e) {
      LOGGER.error("des_decrypt error:", e);
      return null;
    }
  }
  // 3DES加密
  public static byte[] trides_crypt(byte key[], byte data[]) {
    try {
      byte[] k = new byte[24];
      int len = data.length;
      if (data.length % 8 != 0) {
        len = data.length - data.length % 8 + 8;
      }
      byte[] needData = null;
      if (len != 0)
        needData = new byte[len];
      for (int i = 0; i < len; i++) {
        needData[i] = 0x00;
      }
      System.arraycopy(data, 0, needData, 0, data.length);
      if (key.length == 16) {
        System.arraycopy(key, 0, k, 0, key.length);
        System.arraycopy(key, 0, k, 16, 8);
      } else {
        System.arraycopy(key, 0, k, 0, 24);
      }
      KeySpec ks = new DESedeKeySpec(k);
      SecretKeyFactory kf = SecretKeyFactory.getInstance("DESede");
      SecretKey ky = kf.generateSecret(ks);
      Cipher c = Cipher.getInstance(TriDes);
      c.init(Cipher.ENCRYPT_MODE, ky);
      return c.doFinal(needData);
    } catch (Exception e) {
      LOGGER.error("trides_crypt error:", e);
      return null;
    }
  }
  // 3DES解密
  public static byte[] trides_decrypt(byte key[], byte data[]) {
    try {
      byte[] k = new byte[24];
      int len = data.length;
      if (data.length % 8 != 0) {
        len = data.length - data.length % 8 + 8;
      }
      byte[] needData = null;
      if (len != 0)
        needData = new byte[len];
      for (int i = 0; i < len; i++) {
        needData[i] = 0x00;
      }
      System.arraycopy(data, 0, needData, 0, data.length);
      if (key.length == 16) {
        System.arraycopy(key, 0, k, 0, key.length);
        System.arraycopy(key, 0, k, 16, 8);
      } else {
        System.arraycopy(key, 0, k, 0, 24);
      }
      KeySpec ks = new DESedeKeySpec(k);
      SecretKeyFactory kf = SecretKeyFactory.getInstance("DESede");
      SecretKey ky = kf.generateSecret(ks);
      Cipher c = Cipher.getInstance(TriDes);
      c.init(Cipher.DECRYPT_MODE, ky);
      return c.doFinal(needData);
    } catch (Exception e) {
      LOGGER.error("trides_decrypt error:", e);
      return null;
    }
  }
  public static String getPass(String source) {
    byte[] data= hexToBytes(source);
    byte[] key ="111111111111111111111111111a1.1.".getBytes();
    String result = byte2hex(trides_decrypt(key, data)).toUpperCase();
    return result.substring(2, 8);
  }
  public static String byte2hex(byte[] data) {
    StringBuffer sb = new StringBuffer();
    for (int i = 0; i < data.length; i++) {
      String temp = Integer.toHexString(((int) data[i]) & 0xFF);
      for (int t = temp.length(); t < 2; t++) {
        sb.append("0");
      }
      sb.append(temp);
    }
    return sb.toString();
  }
  public static byte[] hexToBytes(String str) {
    if (str == null) {
      return null;
    } else if (str.length() < 2) {
      return null;
    } else {
      int len = str.length() / 2;
      byte[] buffer = new byte[len];
      for (int i = 0; i < len; i++) {
        buffer[i] = (byte) Integer.parseInt(str.substring(i * 2, i * 2 + 2), 16);
      }
      return buffer;
    }
  }
}

  因為客戶端只負(fù)責(zé)數(shù)據(jù)加密,所以我這里只寫了加密的部分。由于java和C#語言很相似,所以我就仿這他們給的java代碼改成C#的,當(dāng)然也在網(wǎng)上參考了一些代碼,不過中間還是出現(xiàn)了些問題,比如C#不支持弱密鑰(把密鑰弄復(fù)雜點),因為沒注意大小寫造成加密結(jié)果不一致等等。編程這東西一個點都能讓整個系統(tǒng)崩潰,所以小細(xì)節(jié)很重要!?。?/p>

public class DESHelper
{
  /// <summary>
  /// 將密碼轉(zhuǎn)成直接數(shù)組
  /// </summary>
  /// <param name="str"></param>
  /// <returns></returns>
  public static byte[] HexToBytes(String str)
  {
    if (str == null)
    {
      return null;
    }
    else if (str.Length < 2)
    {
      return null;
    }
    else
    {
      int len = str.Length / 2;
      byte[] buffer = new byte[len];
      for (int i = 0; i < len; i++)
      {
        var temp = str.Substring(i * 2, 2);
        buffer[i] = (byte)Convert.ToInt32(temp, 16);
      }
      return buffer;
    }
  }
  /// <summary>
  /// 3DES加密
  /// </summary>
  /// <param name="key"></param>
  /// <param name="data"></param>
  /// <returns></returns>
  public static byte[] GetDes3EncryptedText(byte[] key, byte[] data)
  {
    byte[] k = new byte[24];
    int len = data.Length;
    if (data.Length % 8 != 0)
    {
      len = data.Length - data.Length % 8 + 8;
    }
    byte[] needData = null;
    if (len != 0)
      needData = new byte[len];
    for (int i = 0; i < len; i++)
    {
      needData[i] = 0x00;
    }
    Buffer.BlockCopy(data, 0, needData, 0, data.Length);
    if (key.Length == 16)
    {
      Buffer.BlockCopy(key, 0, k, 0, key.Length);
      Buffer.BlockCopy(key, 0, k, 16, 8);
    }
    else
    {
      Buffer.BlockCopy(key, 0, k, 0, 24);
    }
    var des3 = new TripleDESCryptoServiceProvider();
    des3.Key = k;
    des3.Mode = CipherMode.ECB;
    des3.Padding = PaddingMode.Zeros;
    using (MemoryStream ms = new MemoryStream())
    using (CryptoStream cs = new CryptoStream(ms, des3.CreateEncryptor(), CryptoStreamMode.Write))
    {
      cs.Write(data, 0, data.Length);
      cs.FlushFinalBlock();
      return ms.ToArray();
    }
  }
  /// <summary>
  /// 將加密結(jié)果轉(zhuǎn)成字符串
  /// </summary>
  /// <param name="data"></param>
  /// <returns></returns>
  public static String GetByte2Hex(byte[] data)
  {
    StringBuilder sb = new StringBuilder();
    for (int i = 0; i < data.Length; i++)
    {
      String temp = string.Format("{0:X}", ((int)data[i]) & 0xFF);
      for (int t = temp.Length; t < 2; t++)
      {
        sb.Append("0");
      }
      sb.Append(temp);
    }
    return sb.ToString();
  }
}

以上所述就是本文的全部內(nèi)容了,希望大家能夠喜歡。

相關(guān)文章

  • 淺談C#泛型的用處與特點

    淺談C#泛型的用處與特點

    泛型是 2.0 版 C# 語言和公共語言運行庫 (CLR) 中的一個新功能。泛型將類型參數(shù)的概念引入 .NET Framework,類型參數(shù)使得設(shè)計如下類和方法成為可能:這些類和方法將一個或多個類型的指定推遲到客戶端代碼聲明并實例化該類或方法的時候
    2013-09-09
  • C#:(變量)字段和局部變量的作用域沖突

    C#:(變量)字段和局部變量的作用域沖突

    C#:字段和局部變量的作用域沖突,需要的朋友可以參考一下
    2013-02-02
  • C# Email發(fā)送郵件 對方打開郵件可獲得提醒

    C# Email發(fā)送郵件 對方打開郵件可獲得提醒

    這篇文章主要為大家詳細(xì)介紹了C# Email發(fā)送郵件功能,對方打開通知你,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-11-11
  • C#中DataGridView操作技巧

    C#中DataGridView操作技巧

    這篇文章主要介紹了C#中DataGridView操作技巧,包括了DataGridView的初始化、添加行、添加列、排序等操作技巧,非常具有實用價值,需要的朋友可以參考下
    2014-12-12
  • unity實現(xiàn)玻璃效果

    unity實現(xiàn)玻璃效果

    這篇文章主要為大家詳細(xì)介紹了unity實現(xiàn)玻璃效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-04-04
  • C#實例代碼之抽獎升級版可以經(jīng)表格數(shù)據(jù)導(dǎo)入數(shù)據(jù)庫,抽獎設(shè)置,補抽

    C#實例代碼之抽獎升級版可以經(jīng)表格數(shù)據(jù)導(dǎo)入數(shù)據(jù)庫,抽獎設(shè)置,補抽

    這篇文章主要介紹了C#實例代碼之抽獎升級版可以經(jīng)表格數(shù)據(jù)導(dǎo)入數(shù)據(jù)庫,抽獎設(shè)置,補抽 的相關(guān)資料,需要的朋友可以參考下
    2016-01-01
  • C#中ListView用法實例

    C#中ListView用法實例

    我們經(jīng)常會在應(yīng)用程序中使用列表的形式來展現(xiàn)一些內(nèi)容,所以學(xué)好ListView是非常必需的,下面這篇文章主要給大家介紹了關(guān)于C#中ListView用法的相關(guān)資料,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-06-06
  • C#查詢SqlServer數(shù)據(jù)庫并返回單個值的方法

    C#查詢SqlServer數(shù)據(jù)庫并返回單個值的方法

    這篇文章主要介紹了C#查詢SqlServer數(shù)據(jù)庫并返回單個值的方法,涉及C#操作SQLServer數(shù)據(jù)庫查詢的相關(guān)技巧,需要的朋友可以參考下
    2015-06-06
  • C#自定讀取配置文件類實例

    C#自定讀取配置文件類實例

    這篇文章主要介紹了C#自定讀取配置文件類,實例分析了C#讀取配置文件的技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-03-03
  • C#使用Data?Annotations進(jìn)行手動數(shù)據(jù)驗證

    C#使用Data?Annotations進(jìn)行手動數(shù)據(jù)驗證

    這篇文章介紹了C#使用Data?Annotations進(jìn)行手動數(shù)據(jù)驗證的方法,文中通過示例代碼介紹的非常詳細(xì)。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-06-06

最新評論