C# 3DES加密詳解
最近一個(gè)項(xiàng)目中,因?yàn)榉?wù)端是用的java開(kāi)發(fā)的,客戶端是用的C#,由于通信部分采用到了3DES加密,所以做個(gè)記錄,以備以后需要的時(shí)候直接用。
這是對(duì)方(java)的加密算法,和網(wǎng)上流傳的代碼也差不多(主密鑰直接寫(xiě)死了,方便測(cè)試)
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; } } }
因?yàn)榭蛻舳酥回?fù)責(zé)數(shù)據(jù)加密,所以我這里只寫(xiě)了加密的部分。由于java和C#語(yǔ)言很相似,所以我就仿這他們給的java代碼改成C#的,當(dāng)然也在網(wǎng)上參考了一些代碼,不過(guò)中間還是出現(xiàn)了些問(wèn)題,比如C#不支持弱密鑰(把密鑰弄復(fù)雜點(diǎn)),因?yàn)闆](méi)注意大小寫(xiě)造成加密結(jié)果不一致等等。編程這東西一個(gè)點(diǎn)都能讓整個(gè)系統(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(); } }
以上所述就是本文的全部?jī)?nèi)容了,希望大家能夠喜歡。
- C#的3DES加密解密算法實(shí)例代碼
- C#編寫(xiě)DES加密、解密類
- des加密解密源碼 C# key值問(wèn)題分析
- php實(shí)現(xiàn)和c#一致的DES加密解密實(shí)例
- C#使用DES和AES實(shí)現(xiàn)加密解密功能示例
- c#通過(guò)DES加密算法加密大文件的方法
- C# DES加密算法中向量的作用詳細(xì)解析
- C#實(shí)現(xiàn)對(duì)AES加密和解密的方法
- 基于C#對(duì)用戶密碼使用MD5加密與解密
- asp實(shí)現(xiàn)的sha1加密解密代碼(和C#兼容)
- C#編寫(xiě)的Base64加密和解密類
- C#實(shí)現(xiàn)簡(jiǎn)單的3DES加密解密功能示例
相關(guān)文章
C# Email發(fā)送郵件 對(duì)方打開(kāi)郵件可獲得提醒
這篇文章主要為大家詳細(xì)介紹了C# Email發(fā)送郵件功能,對(duì)方打開(kāi)通知你,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-11-11C#實(shí)例代碼之抽獎(jiǎng)升級(jí)版可以經(jīng)表格數(shù)據(jù)導(dǎo)入數(shù)據(jù)庫(kù),抽獎(jiǎng)設(shè)置,補(bǔ)抽
這篇文章主要介紹了C#實(shí)例代碼之抽獎(jiǎng)升級(jí)版可以經(jīng)表格數(shù)據(jù)導(dǎo)入數(shù)據(jù)庫(kù),抽獎(jiǎng)設(shè)置,補(bǔ)抽 的相關(guān)資料,需要的朋友可以參考下2016-01-01C#查詢SqlServer數(shù)據(jù)庫(kù)并返回單個(gè)值的方法
這篇文章主要介紹了C#查詢SqlServer數(shù)據(jù)庫(kù)并返回單個(gè)值的方法,涉及C#操作SQLServer數(shù)據(jù)庫(kù)查詢的相關(guān)技巧,需要的朋友可以參考下2015-06-06C#使用Data?Annotations進(jìn)行手動(dòng)數(shù)據(jù)驗(yàn)證
這篇文章介紹了C#使用Data?Annotations進(jìn)行手動(dòng)數(shù)據(jù)驗(yàn)證的方法,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-06-06