注释都在代码里了,干了:
import javax.crypto.Cipher;
import javax.crypto.KeyGenerator;
import javax.crypto.SecretKey;
import javax.crypto.spec.SecretKeySpec;
import javax.xml.bind.annotation.adapters.HexBinaryAdapter;import org.apache.commons.codec.binary.Hex;public class Main {static String src = "Hello,sahadev!";public static void main(String[] args) {DES();}public static void DES() {try {// 以DES的方式初始化Key生成器KeyGenerator keyGenerator = KeyGenerator.getInstance("DES");keyGenerator.init(56);// 设置密钥的长度为56位// 生成一个KeySecretKey generateKey = keyGenerator.generateKey();// 转变为字节数组byte[] encoded = generateKey.getEncoded();// 生成密钥字符串String encodeHexString = Hex.encodeHexString(encoded);System.out.println("Key : " + encodeHexString);// 再把我们的字符串转变为字节数组,可以用于另一方使用,验证byte[] decodeHex = Hex.decodeHex(encodeHexString.toCharArray());// 生成密钥对象SecretKeySpec secretKeySpec = new SecretKeySpec(decodeHex, "DES");// 获取加解密实例Cipher cipher = Cipher.getInstance("DES/ECB/PKCS5Padding");// 初始化加密模式cipher.init(Cipher.ENCRYPT_MODE, secretKeySpec);// 加密byte[] doFinal = cipher.doFinal(src.getBytes());System.out.println("加密结果 : " + new HexBinaryAdapter().marshal(doFinal));// 初始化解密模式cipher.init(Cipher.DECRYPT_MODE, secretKeySpec);// 解密byte[] doFinal2 = cipher.doFinal(doFinal);// 输出解密结果System.out.println("解密结果 : " + new String(doFinal2));} catch (Exception e) {e.printStackTrace();}}}
附上输出结果:
Key : 619b862f5e2aad40
加密结果 : D98FA80E83593710C0686370665C2FEC
解密结果 : Hello,sahadev!