Spring Boot最大的特色就是自动配置了,大大的减小了传统Spring框架的繁琐配置,经过几行简单的配置就能够完成其余组件的接入。好比你想要链接mysql数据库,只须要的配置文件里面加入mysql的一些配置信息就能够了。为了保护数据的安全性,愈来愈多的公司选择加密这些重要信息。接下来一块儿来看看如何实现配置加密文件而且成功链接数据库的。java
配置信息加密有好几种方式,这里我只详细的写一下我比较经常使用的一种方式。首先经过某种加密算法将用户名和密码进行加密,而后在配置文件中用加密串代替原来的明文。而后自定义数据源,在自定义数据源中解密用户名和密码。mysql
SpringBoot的自动装配,之前的推文中也详细的讲到过,今天简单来复习一下。在每一个Spring Boot的应用的启动类上都能发现有一个注解@SpringBootApplication
,这个注解包含的注解@EnableAutoConfiguration
就是用来完成自动装配的。这个注解经过导入类AutoConfigurationImportSelector
,这个类中有一个方法selectImports
,其做用就是扫描全部jar包中的META-INF/spring.factories
文件,去加载里面的具体实现类,完成自动装配。git
在spring-boot-autoconfigure
jar包的META-INF/spring.factories
文件中指定了一个类用来加载数据库配置信息,这个类就是org.springframework.boot.autoconfigure.jdbc.DataSourceAutoConfiguration
。github
这里使用HikariDataSource
做为自定义的数据源,自定义的数据源目的就是为了解密配置文件中的配置信息。面试
@Configuration public class DataSourceConfiguration { @Autowired DataSourceProperties properties; @Bean public DataSource dataSource() throws Exception{ String username = Des3.decryptThreeDESECB(properties.getUsername(),Des3.DES3KEY); String password = Des3.decryptThreeDESECB(properties.getPassword(),Des3.DES3KEY); HikariDataSource dataSource = new HikariDataSource(); dataSource.setDriverClassName(properties.getDriverClassName()); dataSource.setJdbcUrl(properties.getUrl()); dataSource.setUsername(username); dataSource.setPassword(password); return dataSource; } }
配置文件信息以下:算法
spring: datasource: driver-class-name: com.mysql.cj.jdbc.Driver url: jdbc:mysql://localhost:3306/xxx username: aMkeRCLWqNw= password: rq-fzucH32I=
具体的加解密算法这里就不在说起了,根据具体要求选择一种可逆的加密算法就能够了,若是还不是很了解加密算法的种类,能够参考我之前写的一篇文章——面试官:说一下你经常使用的加密算法。spring
此是spring-boot-route系列的第十一篇文章,这个系列的文章都比较简单,主要目的就是为了帮助初次接触Spring Boot 的同窗有一个系统的认识。本文已收录至个人github,欢迎各位小伙伴star
!sql
github:https://github.com/binzh303/s...数据库
若是以为文章不错,欢迎关注、点赞、收藏,大家的支持是我创做的动力,感谢你们。安全
若是文章写的有问题,请不要吝啬,欢迎留言指出,我会及时核查修改。
若是你还想更加深刻的了解我,能够微信搜索「Java旅途」进行关注。回复「1024」便可得到学习视频及精美电子书。天天7:30准时推送技术文章,让你的上班路不在孤独,并且每个月还有送书活动,助你提高硬实力!