国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > C# > 正文

C# 3DES加密詳解

2020-01-24 01:46:22
字體:
供稿:網(wǎng)友

最近一個項目中,因為服務(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;    }  }}

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

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)容了,希望大家能夠喜歡。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 贺兰县| 贵阳市| 浮梁县| 吉木乃县| 若羌县| 七台河市| 邢台县| 武鸣县| 吉林市| 汶川县| 房产| 海原县| 松桃| 兴海县| 开远市| 望都县| 大荔县| 兴宁市| 五常市| 华蓥市| 包头市| 南川市| 富裕县| 徐州市| 枣庄市| 读书| 池州市| 阿拉善盟| 柘荣县| 威海市| 松滋市| 元江| 宣威市| 宽城| 许昌市| 文成县| 莱阳市| 兴宁市| 奉节县| 肃北| 治多县|