springboot按自定义解密规则读取properties
程序员文章站
2022-03-12 20:52:39
...
springboot在启动时会读取properties中的配置,很多时候例如数据库的都是加密的,这会导致项目启动无法正确连接到数据库。这时候我们就需要对加密的字段进行解密处理,然后再读取。
分两种情况,一是配置文件在resource目录下,这时候比较方便,再启动类的main方法中做处理:
//EncryptUtil是自定义解密工具类,提供一个方法返回解密后的Properties对象
EncryptUtil encrypt = new EncryptUtil();
Properties prop = new Properties();
URL url = DemoApplication.class.getClassLoader().getResource("jdbc.properties");
prop.load(url.openStream());
SpringApplication app = new SpringApplication(DemoApplication.class);
//调用方法得到解密后的Properties对象
Properties properties = encrypt.encryptProp(prop);
//设置springboot启动时去读取解密后的properties
app.setDefaultProperties(properties);
app.setBannerMode(Banner.Mode.OFF);
app.run(args);
这里需要注意,需要解密的内容不要放到application.properties中,否则setDefaultProperties(properties)后springboot还会默认去加载application.properties覆盖掉之前读取的内容。
另一种情况是properties放在jar包外,这时候需要多一层处理,获取jar包所在同级目录。
然后按照得到的路径去读到需要解密的properties,后续处理相同。大体思路就是读取需要解密的properties,然后通过自定义的解密工具类进行解密,返回解密后的properties对象,最后setDefaultProperties(),收工。
下一篇: 对称加密算法之Java 3DES算法应用