欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

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(),收工。