3DES双倍长加密

import java.security.SecureRandom;
import javax.crypto.Cipher;
import javax.crypto.SecretKey;
import javax.crypto.SecretKeyFactory;
import javax.crypto.spec.DESKeySpec;
//结果与DES算法工具一致
public class DES{ public static void main(String[] args) { String key = "F2C04AD9F598EE61C424C9C7D39BA75F"; String data = "06321643FF8B67EB"; String des = encryptECB3Des(key,data); System.out.println(des); } public static String encryptECB3Des(String key, String src) { System.out.println("encryptECB3Des->" + "key:" + key); System.out.println("encryptECB3Des->" + "src:" + src); int len = key.length(); if (key == null || src == null) { return null; } if (src.length() % 16 != 0) { return null; } if (len == 32) { String outData = ""; String str = ""; for (int i = 0; i < src.length() / 16; i++) { str = src.substring(i * 16, (i + 1) * 16); outData += encECB3Des(key, str); } return outData; } return null; } public static String encECB3Des(String key, String src) { byte[] temp = null; byte[] temp1 = null; temp1 = encryptDes(hexStringToBytes(key.substring(0, 16)), hexStringToBytes(src)); temp = decryptDes(hexStringToBytes(key.substring(16, 32)), temp1); temp1 = encryptDes(hexStringToBytes(key.substring(0, 16)), temp); return bytesToHexString(temp1); } public static String decECB3Des(String key, String src) { byte[] temp2 = decryptDes(hexStringToBytes(key.substring(0, 16)), hexStringToBytes(src)); byte[] temp1 = encryptDes(hexStringToBytes(key.substring(16, 32)), temp2); byte[] dest = decryptDes(hexStringToBytes(key.substring(0, 16)), temp1); return bytesToHexString(dest); } public static String bytesToHexString(byte[] src) { StringBuilder stringBuilder = new StringBuilder(""); if (src == null || src.length <= 0) { return null; } for (int i = 0; i < src.length; i++) { int v = src[i] & 0xFF; String hv = Integer.toHexString(v); if (hv.length() < 2) { stringBuilder.append(0); } stringBuilder.append(hv); } return stringBuilder.toString(); } public static byte[] hexStringToBytes(String hexString) { if (hexString == null || hexString.equals("")) { return null; } hexString = hexString.toUpperCase(); int length = hexString.length() / 2; char[] hexChars = hexString.toCharArray(); byte[] d = new byte[length]; for (int i = 0; i < length; i++) { int pos = i * 2; d[i] = (byte) (charToByte(hexChars[pos]) << 4 | charToByte(hexChars[pos + 1])); } return d; } private static byte charToByte(char c) { return (byte) "0123456789ABCDEF".indexOf(c); } /** * 3DES(双倍长) 解密 * * @param keybyte * @param src * @return */ public static String decryptECB3Des(String key, String src) { if (key == null || src == null) { return null; } if (src.length() % 16 != 0) { return null; } if (key.length() == 32) { String outData = ""; String str = ""; for (int i = 0; i < src.length() / 16; i++) { str = src.substring(i * 16, (i + 1) * 16); outData += decECB3Des(key, str); } return outData; } return null; } /** * DES加密 * */ public static byte[] encryptDes(byte[] key, byte[] src) { try { // 创建一个DESKeySpec对象 DESKeySpec desKey = new DESKeySpec(key); // 创建一个密匙工厂 SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES"); // 将DESKeySpec对象转换成SecretKey对象 SecretKey secretKey = keyFactory.generateSecret(desKey); // Cipher对象实际完成解密操作 Cipher cipher = Cipher.getInstance("DES/ECB/NoPadding"); // 用密匙初始化Cipher对象 cipher.init(Cipher.ENCRYPT_MODE, secretKey); // 现在,获取数据并加密 // 正式执行加密操作 return cipher.doFinal(src); } catch (Exception e) { e.printStackTrace(); } return null; } /** * des解密 * * @param key * @param src * @return */ public static byte[] decryptDes(byte[] key, byte[] src) { try { // DES算法要求有一个可信任的随机数源 SecureRandom random = new SecureRandom(); // 创建一个DESKeySpec对象 DESKeySpec desKey = new DESKeySpec(key); // 创建一个密匙工厂 SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES"); // 将DESKeySpec对象转换成SecretKey对象 SecretKey secretKey = keyFactory.generateSecret(desKey); // Cipher对象实际完成解密操作 Cipher cipher = Cipher.getInstance("DES/ECB/NoPadding"); // 用密匙初始化Cipher对象 cipher.init(Cipher.DECRYPT_MODE, secretKey, random); // 现在,获取数据并加密 // 正式执行加密操作 return cipher.doFinal(src); } catch (Exception e) { e.printStackTrace(); } return null; } }

 

转载于:https://www.cnblogs.com/bchange/p/9181989.html

3DES(或称为Triple DES)是三重数据加密算法(TDEA,Triple Data Encryption Algorithm)块密码的通称。它相当于是对每个数据块应用三次DES加密算法。 最早的定义了该算法的标准(ANS X9.52,1998年发布)将其描述为“三重数据加密算法(TDEA)”— 即为ANSI X3.92中定义的数据加密算法(DEA)的三次重复操作— 而完全没有使用术语“3DES”或“DES”。FIPS PUB 46-3(1999)定义了“三重数据加密算法”(TDEA),也使用了术语“Triple DES”和“DES”。该标准中互换的使用“数据加密算法”(DEA)和“DES”的概念,其中以此开始DES的定义: 数据加密标准(DES)应当包括下文中的数据加密算法(DES[4])与三重数据加密算法(TDEA,如ANSI X9.52中所描述的) NIST SP 800-67(2004,2008[5])主要使用术语TDEA,但也提到了“Triple DES(TDEA)”。ISO/IEC 18033-3(2005)使用“TDEA”,但其中提到: TDEA通称Triple DES(数据加密标准)。 没有一个定义了本算法的标准使用术语“3DES”。 3DESughhhg34465345556555678==算法== 3DES使用“密钥包”,其包含3个DES密钥,K1,K2和K3,均为56位(除去奇偶校验位)。加密算法为: 密文 = EK3(DK2(EK1(平文))) 也就是说,使用K1为密钥进行DES加密,再用K2为密钥进行DES“解密”,最后以K3进行DES加密。 而解密则为其反过程: 平文 = DK1(EK2(DK3(密文))) 即以K3解密,以K2“加密”,最后以K1解密。 每次加密操作都只处理64位数据,称为一块。 无论是加密还是解密,中间一步都是前后两步的逆。这种做法提高了使用密钥选项2时的算法强度,并在使用密钥选项3时与DES兼容。 密钥选项[编辑] 标准定义了三种密钥选项: 密钥选项1:三个密钥是独立的。 密钥选项2:K1和K2是独立的,而K3=K1 密钥选项3:三个密钥均相等,即K1=K2=K3 密钥选项1的强度最高,拥有3 x 56 = 168个独立的密钥位。 密钥选项2的安全性稍低,拥有2 x 56 = 112个独立的密钥位。该选项比简单的应用DES两次的强度较高,即使用K1和K2,因为它可以防御中途相遇攻击。 密钥选项3等同与DES,只有56个密钥位。这个选项提供了与DES的兼容性,因为第1和第2次DES操作相互抵消了。该选项不再为国家标准科技协会(NIST)所建议[6],亦不为ISO/IEC 18033-3所支持。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值