配置文件加密了数据库配置信息为什么Spring Boot仍能连接数据库
这篇"配置文件加密了数据库配置信息为什么Spring Boot仍能连接数据库"文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇"配置文件加密了数据库配置信息为什么Spring Boot仍能连接数据库"文章吧。
Spring Boot 最大的特点就是自动配置了,大大的减少了传统 Spring 框架的繁琐配置,通过几行简单的配置就可以完成其他组件的接入。比如你想要连接 mysql 数据库,只需要的配置文件里面加入 mysql 的一些配置信息就可以了。为了保护数据的安全性,越来越多的公司选择加密这些重要信息。接下来一起来看看如何实现配置加密文件并且成功连接数据库的。
配置信息加密有好几种方式,这里我只详细的写一下我比较常用的一种方式。首先通过某种加密算法将用户名和密码进行加密,然后在配置文件中用加密串代替原来的明文。然后自定义数据源,在自定义数据源中解密用户名和密码。
SpringBoot自动装配
Spring Boot 的自动装配,以前的推文中也详细的讲到过,今天简单来复习一下。在每个 Spring Boot 的应用的启动类上都能发现有一个注解@SpringBootApplication
,这个注解包含的注解@EnableAutoConfiguration
就是用来完成自动装配的。这个注解通过导入类AutoConfigurationImportSelector
,这个类中有一个方法selectImports
,其作用就是扫描所有jar包中的META-INF/spring.factories
文件,去加载里面的具体实现类,完成自动装配。
在spring-boot-autoconfigure
jar包的META-INF/spring.factories
文件中指定了一个类用来加载数据库配置信息,这个类就是org.springframework.boot.autoconfigure.jdbc.DataSourceAutoConfiguration
。
自定义数据源
这里使用HikariDataSource
作为自定义的数据源,自定义的数据源目的就是为了解密配置文件中的配置信息。
@Configurationpublic 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 Boot仍能连接数据库"这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注行业资讯频道。