Spring 工程数据库密码用户配置问题

通过启动脚本注入

在 Spring 工程中,连接 MySQL 数据库的用户名和密码通常保存在配置文件中(比如 application.properties 或者 application.yml),而在跑测试用例时,这些配置信息往往需要与生产环境隔离开来。

可以使用 Spring 的配置文件来解决这个问题,具体方法如下:

在主配置文件中只写明用户名和密码的占位符,例如:
spring.datasource.username= M Y S Q L U S E R s p r i n g . d a t a s o u r c e . p a s s w o r d = {MYSQL_USER} spring.datasource.password= MYSQLUSERspring.datasource.password={MYSQL_PASSWORD}
其中 ${MYSQL_USER} 和 ${MYSQL_PASSWORD} 都是占位符。

在开发和测试环境下新建配置文件 application-dev.properties 或 application-test.properties,在这些配置文件中分别指定用户名和密码,例如:
MYSQL_USER=username
MYSQL_PASSWORD=password
在真正执行时,使用 -D 参数来指定环境变量,例如:
java -jar app.jar -Dspring.profiles.active=dev
-DMYSQL_USER=test_user
-DMYSQL_PASSWORD=my_password
这样在运行时会依次读取主配置文件和环境变量,将占位符替换为具体的用户名和密码,从而获取完整的数据库链接信息。

需要注意的是,将密码直接写在开发和测试环境的配置文件中并不安全,因此在实际应用中需要对配置文件进行加密或者使用其他更安全的方式来保护密码信息。

Simply put

To handle the password user issue for linking MySQL in a Spring project, you can use the following steps:

  1. Store the password securely in a configuration file or environment variable.
  2. Use Spring’s PropertyPlaceholderConfigurer to load the password from the configuration file or environment variable.
  3. Use Spring’s DataSource to create a connection to MySQL using the loaded password.
  4. Make sure to encrypt the configuration file or environment variable to ensure security.

其它

以下是处理敏感数据安全问题的一些常见方法:

加密敏感数据:可以使用加密算法将敏感数据加密保存,并在读取时解密。

加密配置文件:可以使用加密处理配置文件,比如使用 Jasypt(Java Simplified Encryption)框架对配置文件进行加密。

放置于安全的位置:将敏感数据保存在只有受信任用户可以访问的安全位置中,比如操作系统的安全文件夹或密码保险箱中。

使用环境变量:可以使用操作系统提供的环境变量将敏感数据配置到系统中,这样就不需要将它们写入到文件中。

集中管理:可以设置一个集中的配置管理中心来管理敏感数据,只有被授权访问的人才能访问这个中心。

使用安全框架:Spring 框架已经提供了一些安全框架,比如 Spring Security。可以使用这些框架来管理用户访问权限、身份认证等。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

P("Struggler") ?

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值