如何在 Spring Boot 中安全读取账号密码等

在开发 Spring Boot 项目时,经常需要实现发送邮件的功能,例如用户注册的邮箱验证码、忘记密码邮件等。通常,邮箱账号和密码会写在配置文件 application.yml 中,但这样做存在安全隐患:

  • 敏感信息暴露:一旦提交到 Git 仓库,邮箱账号和密码就可能被泄露。
  • 多环境不灵活:开发、测试、生产环境可能使用不同邮箱,如果写死在配置文件里,每次都需要修改。

为了解决这个问题,我们可以将 邮箱账号和密码存放到环境变量 中,让 Spring Boot 从环境变量安全读取。下面详细说明操作步骤。


1️⃣ 在电脑/服务器上设置环境变量

Windows PowerShell

powershell 复制代码
setx MAIL_USERNAME "0811500009@163.com"
setx MAIL_PASSWORD "eagfsdcJssgXsa"

Linux / macOS

bash 复制代码
export MAIL_USERNAME="0811500009@163.com"
export MAIL_PASSWORD="eagfsdcJssgXsa"

⚠️ 设置好后,最好重新启动 IDE 或终端,让环境变量生效。


2️⃣ 修改 application.yml 使用占位符

在配置文件中使用 ${环境变量名} 形式占位,Spring Boot 会自动读取:

yaml 复制代码
mail:
  host: smtp.163.com
  username: ${MAIL_USERNAME}   # 从环境变量读取
  password: ${MAIL_PASSWORD}   # 从环境变量读取
  code:
    overtime: 5

这样就不用在配置文件里暴露邮箱账号和密码。


3️⃣ Java 代码里使用

通过 @ConfigurationProperties 注入配置:

java 复制代码
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.stereotype.Component;

@Component
@ConfigurationProperties(prefix = "mail")
public class MailCodeConfig {
    private String host;
    private String username;
    private String password;
    private Code code;

    public static class Code {
        private int overtime;

        // getter / setter
    }

    // getter / setter
}

然后在代码里直接使用:

java 复制代码
String username = mailCodeConfig.getUsername();
String password = mailCodeConfig.getPassword();
相关推荐
你的代码我的心2 分钟前
微信开发者工具开发网页,不支持tailwindcss v4怎么办?
开发语言·javascript·ecmascript
爱吃山竹的大肚肚3 分钟前
文件上传大小超过服务器限制
java·数据库·spring boot·mysql·spring
黄昏恋慕黎明3 分钟前
测试模型讲解
java
瑞雪兆丰年兮6 分钟前
[从0开始学Java|第十二天]学生管理系统升级
java·开发语言
弹简特6 分钟前
【JavaSE-网络部分03】网络原理-泛泛介绍各个层次
java·开发语言·网络
执风挽^6 分钟前
Python_func_basic
开发语言·python·算法·visual studio code
周杰伦的稻香6 分钟前
Hexo搭建教程
java·node.js
倔强的石头1067 分钟前
飞算JavaAI如何提升重塑Java开发体验
java·飞算javaai·ai开发工具
编程彩机8 分钟前
互联网大厂Java面试:从Spring Boot到分布式事务的技术场景解析
spring boot·kafka·分布式事务·微服务架构·java面试·技术解析
努力d小白10 分钟前
leetcode438.找到字符串中所有字母异位词
java·javascript·算法