日常我们开发中 yml 配置文件中应该会存储很多程序用到的变量值,但是涉及到一些关键性的比如密码之类的配置项,就会有很大的安全隐患,一旦源码泄露,那我们的数据库也就不安全了。

我们的解决思路也很简单,那就是涉及敏感信息的内容,给它做一个加密处理,这里我们用现成的加密工具组件叫 jasypt 。
在 pom.xml 中引入依赖 Jar
com.github.ulisesbocchio jasypt-spring-boot-starter 3.0.5
jasypt:encryptor:password: ILoveFeiGe这里我是自己写了一个接口 controller
@Slf4j
@Controller
@RequestMapping("/test")
public class TestController {@Autowiredprivate StringEncryptor encryptor;@RequestMapping(value="jm",method = RequestMethod.POST)@ResponseBodypublic ReturnData jm(String content) {System.out.println("请求加密,加密内容:"+content);try {String contentJm = encryptor.encrypt(content);System.out.println("请求加密,加密后密文:"+contentJm);return new ReturnData(ReturnCode.SUCCESS.getCode(),contentJm,ReturnCode.SUCCESS.getMessage());} catch (Exception e) {System.err.println("请求加密异常:"+e);return new ReturnData(ReturnCode.SYS_ERROR.getCode(),"请求加密异常");}}}
也是为了方便日后再调用此方法。可以看到核心的代码就是注入 StringEncryptor bean 文件,然后执行加密即可。

比如,密文:DFSrFEIsKNAPIUMZcHwjq+kCF9UL/3OH9YnaO7R88kTcZuBvdN/s1Rdp3qwnLBwP
配置文件中用ENC()包裹密文参数即可
注:这里ENC() 的写法是固定的,程序会自动解析执行解密的。
我们的 jasypt 秘钥还是在配置文件中,还是不安全的。
服务器上启动 Jar 只需要用如下命令即可:
java -jar xxx.jar --jasypt.encryptor.password=ILoveFeiGe那本地运行调试时,也可以指定这个启动参数:


这样直接运行即可,也能保证敏感信息不存在于任何文件中。
下一篇:求与下一站巨星相似的小说