DES 是一种对称加密算法,所谓对称加密算法就是:加密和解密使用相同密钥的算法。DES 加密算法出自 IBM 的研究,后来被美国政府正式采用,之后开始广泛流传。但近些年使用越来越少,因为 DES 使用 56 位密钥,以现代的计算能力,24 小时内即可被破解。
    顺便说一下 3DES(Triple DES),它是 DES 向 AES 过渡的加密算法,使用 3 条 56 位的密钥对数据进行三次加密。是 DES 的一个更安全的变形。它以 DES 为基本模块,通过组合分组方法设计出分组加密算法。比起最初的 DES,3DES 更为安全。
    使用 Java 实现 DES 加密解密,注意密码长度要是 8 的倍数。加密和解密的 Cipher 构造参数一定要相同,不然会报错。
    数据加密标准算法,和BASE64最明显的区别就是有一个工作密钥,该密钥既用于加密、也用于解密,并且要求密钥是一个长度至少大于8位的字符串,示例:

    1. import java.security.Key;
    2. import java.security.SecureRandom;
    3. import javax.crypto.Cipher;
    4. import javax.crypto.KeyGenerator;
    5. import sun.misc.BASE64Decoder;
    6. import sun.misc.BASE64Encoder;
    7. public class DesUtil {
    8. private static Key key;
    9. private static String KEY_STR="myKey";
    10. private static String CHARSETNAME="UTF-8";
    11. private static String ALGORITHM="DES";
    12. static {
    13. try {
    14. //生成DES算法对象
    15. KeyGenerator generator=KeyGenerator.getInstance(ALGORITHM);
    16. //运用SHA1安全策略
    17. SecureRandom secureRandom=SecureRandom.getInstance("SHA1PRNG");
    18. //设置上密钥种子
    19. secureRandom.setSeed(KEY_STR.getBytes());
    20. //初始化基于SHA1的算法对象
    21. generator.init(secureRandom);
    22. //生成密钥对象
    23. key=generator.generateKey();
    24. generator=null;
    25. } catch (Exception e) {
    26. throw new RuntimeException(e);
    27. }
    28. }
    29. /***
    30. * 获取加密的信息
    31. * @param str
    32. * @return
    33. */
    34. public static String getEncryptString(String str) {
    35. //基于BASE64编码,接收byte[]并转换成String
    36. BASE64Encoder encoder = new BASE64Encoder();
    37. try {
    38. //按utf8编码
    39. byte[] bytes = str.getBytes(CHARSETNAME);
    40. //获取加密对象
    41. Cipher cipher = Cipher.getInstance(ALGORITHM);
    42. //初始化密码信息
    43. cipher.init(Cipher.ENCRYPT_MODE, key);
    44. //加密
    45. byte[] doFinal = cipher.doFinal(bytes);
    46. //byte[]to encode好的String 并返回
    47. return encoder.encode(doFinal);
    48. } catch (Exception e) {
    49. throw new RuntimeException(e);
    50. }
    51. }
    52. /***
    53. * 获取解密之后的信息
    54. * @param str
    55. * @return
    56. */
    57. public static String getDecryptString(String str) {
    58. BASE64Decoder decoder = new BASE64Decoder();
    59. try {
    60. //将字符串decode成byte[]
    61. byte[] bytes = decoder.decodeBuffer(str);
    62. //获取解密对象
    63. Cipher cipher = Cipher.getInstance(ALGORITHM);
    64. //初始化解密信息
    65. cipher.init(Cipher.DECRYPT_MODE, key);
    66. //解密
    67. byte[] doFial = cipher.doFinal(bytes);
    68. return new String(doFial, CHARSETNAME);
    69. } catch (Exception e) {
    70. throw new RuntimeException(e);
    71. }
    72. }
    73. }