对Java配置文件中敏感信息进行加解密的工具类

来源:互联网 发布:mysql的sql语句 编辑:程序博客网 时间:2024/05/29 18:39

在 JavaEE 配置文件中,例如 XML 或者 properties 文件,由于某些敏感信息不希望普通人员看见,则可以采用加密的方式存储,程序读取后进行解密。

常见的如: 数据库用户密码,短信平台用户密码,系统间校验的固定密码等。

本工具类参考了 《Spring.3.x企业应用开发实战》一书 5.3节的实现。

完整代码与注释信息如下:

package com.cncounter.util.comm;import java.security.Key;import java.security.SecureRandom;import javax.crypto.Cipher;import javax.crypto.KeyGenerator;import sun.misc.BASE64Decoder;import sun.misc.BASE64Encoder;public class DESUtils {// 密钥private static Key key;// KEY种子private static String KEY_STR = "encrypt@cncounter.com";// 常量public static final String UTF_8 = "UTF-8";public static final String DES = "DES";// 静态初始化static{try {// KEY 生成器KeyGenerator generator = KeyGenerator.getInstance(DES);// 初始化,安全随机算子generator.init(new SecureRandom( KEY_STR.getBytes(UTF_8) ));// 生成密钥key = generator.generateKey();generator = null;} catch (Exception e) {throw new RuntimeException(e);}}/** * 对源字符串加密,返回 BASE64编码后的加密字符串 * @param source 源字符串,明文 * @return 密文字符串 */public static String encode(String source){try {// 根据编码格式获取字节数组byte[] sourceBytes = source.getBytes(UTF_8);// DES 加密模式Cipher cipher = Cipher.getInstance(DES);cipher.init(Cipher.ENCRYPT_MODE, key);// 加密后的字节数组byte[] encryptSourceBytes = cipher.doFinal(sourceBytes);// Base64编码器BASE64Encoder base64Encoder = new BASE64Encoder();return base64Encoder.encode(encryptSourceBytes);} catch (Exception e) {// throw 也算是一种 return 路径throw new RuntimeException(e);}}/** * 对本工具类 encode() 方法加密后的字符串进行解码/解密 * @param encrypted 被加密过的字符串,即密文 * @return 明文字符串 */public static String decode(String encrypted){// Base64解码器BASE64Decoder base64Decoder = new BASE64Decoder();try {// 先进行base64解码byte[] cryptedBytes = base64Decoder.decodeBuffer(encrypted);// DES 解密模式Cipher cipher = Cipher.getInstance(DES);cipher.init(Cipher.DECRYPT_MODE, key);// 解码后的字节数组byte[] decryptStrBytes = cipher.doFinal(cryptedBytes);// 采用给定编码格式将字节数组变成字符串return new String(decryptStrBytes, UTF_8);} catch (Exception e) {// 这种形式确实适合处理工具类throw new RuntimeException(e);}}// 单元测试public static void main(String[] args) {// 需要加密的字符串String email = "renfufei@qq.com";// 加密String encrypted = DESUtils.encode(email);// 解密String decrypted = DESUtils.decode(encrypted);// 输出结果;System.out.println("email: " + email);System.out.println("encrypted: " + encrypted);System.out.println("decrypted: " + decrypted);System.out.println("email.equals(decrypted): " + email.equals(decrypted));}}

1 0
原创粉丝点击