成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

一個依賴搞定Spring Boot 配置文件脫敏

開發 項目管理
今天介紹一種方案,讓你在無感知的情況下實現配置文件的加密、解密。利用一款開源插件:jasypt-spring-boot。

經常會遇到這樣一種情況:項目的配置文件中總有一些敏感信息,比如數據源的url、用戶名、密碼....這些信息一旦被暴露那么整個數據庫都將會被泄漏,那么如何將這些配置隱藏呢??

今天介紹一種方案,讓你在無感知的情況下實現配置文件的加密、解密。利用一款開源插件:jasypt-spring-boot。項目地址如下:

https://github.com/ulisesbocchio/jasypt-spring-boot

使用方法很簡單,整合Spring Boot 只需要添加一個starter。

1. 添加依賴

<dependency>
<groupId>com.github.ulisesbocchio</groupId>
<artifactId>jasypt-spring-boot-starter</artifactId>
<version>3.0.3</version>
</dependency>

2. 配置秘鑰

在配置文件中添加一個加密的秘鑰(任意),如下:

jasypt:
encryptor:
password: Y6M9fAJQdU7jNp5MW

當然將秘鑰直接放在配置文件中也是不安全的,我們可以在項目啟動的時候配置秘鑰,命令如下:

java -jar xxx.jar  -Djasypt.encryptor.password=Y6M9fAJQdU7jNp5MW

3. 生成加密后的數據

這一步驟是將配置明文進行加密,代碼如下:

@SpringBootTest
@RunWith(SpringRunner.class)
public class SpringbootJasyptApplicationTests {

/**
* 注入加密方法
*/
@Autowired
private StringEncryptor encryptor;

/**
* 手動生成密文,此處演示了url,user,password
*/
@Test
public void encrypt() {
String url = encryptor.encrypt("jdbc\\:mysql\\://127.0.0.1\\:3306/test?useUnicode\\=true&characterEncoding\\=UTF-8&zeroDateTimeBehavior\\=convertToNull&useSSL\\=false&allowMultiQueries\\=true&serverTimezone=Asia/Shanghai");
String name = encryptor.encrypt("root");
String password = encryptor.encrypt("123456");
System.out.println("database url: " + url);
System.out.println("database name: " + name);
System.out.println("database password: " + password);
Assert.assertTrue(url.length() > 0);
Assert.assertTrue(name.length() > 0);
Assert.assertTrue(password.length() > 0);
}
}

上述代碼對數據源的url、user、password進行了明文加密,輸出的結果如下:

database url: szkFDG56WcAOzG2utv0m2aoAvNFH5g3DXz0o6joZjT26Y5WNA+1Z+pQFpyhFBokqOp2jsFtB+P9b3gB601rfas3dSfvS8Bgo3MyP1nojJgVp6gCVi+B/XUs0keXPn+pbX/19HrlUN1LeEweHS/LCRZslhWJCsIXTwZo1PlpXRv3Vyhf2OEzzKLm3mIAYj51CrEaN3w5cMiCESlwvKUhpAJVz/uXQJ1spLUAMuXCKKrXM/6dSRnWyTtdFRost5cChEU9uRjw5M+8HU3BLemtcK0vM8iYDjEi5zDbZtwxD3hA=

database name: L8I2RqYPptEtQNL4x8VhRVakSUdlsTGzEND/3TOnVTYPWe0ZnWsW0/5JdUsw9ulm

database password: EJYCSbBL8Pmf2HubIH7dHhpfDZcLyJCEGMR9jAV3apJtvFtx9TVdhUPsAxjQ2pnJ

4. 將加密后的密文寫入配置

jasypt?默認使用ENC()包裹,此時的數據源配置如下:

spring:
datasource:
# 數據源基本配置
username: ENC(L8I2RqYPptEtQNL4x8VhRVakSUdlsTGzEND/3TOnVTYPWe0ZnWsW0/5JdUsw9ulm)
password: ENC(EJYCSbBL8Pmf2HubIH7dHhpfDZcLyJCEGMR9jAV3apJtvFtx9TVdhUPsAxjQ2pnJ)
driver-class-name: com.mysql.jdbc.Driver
url: ENC(szkFDG56WcAOzG2utv0m2aoAvNFH5g3DXz0o6joZjT26Y5WNA+1Z+pQFpyhFBokqOp2jsFtB+P9b3gB601rfas3dSfvS8Bgo3MyP1nojJgVp6gCVi+B/XUs0keXPn+pbX/19HrlUN1LeEweHS/LCRZslhWJCsIXTwZo1PlpXRv3Vyhf2OEzzKLm3mIAYj51CrEaN3w5cMiCESlwvKUhpAJVz/uXQJ1spLUAMuXCKKrXM/6dSRnWyTtdFRost5cChEU9uRjw5M+8HU3BLemtcK0vM8iYDjEi5zDbZtwxD3hA=)
type: com.alibaba.druid.pool.DruidDataSource

上述配置是使用默認的prefix=ENC(、suffix=),當然我們可以根據自己的要求更改,只需要在配置文件中更改即可,如下:

jasypt:
encryptor:
## 指定前綴、后綴
property:
prefix: 'PASS('
suffix: ')'

那么此時的配置就必須使用PASS()包裹才會被解密,如下:

spring:
datasource:
# 數據源基本配置
username: PASS(L8I2RqYPptEtQNL4x8VhRVakSUdlsTGzEND/3TOnVTYPWe0ZnWsW0/5JdUsw9ulm)
password: PASS(EJYCSbBL8Pmf2HubIH7dHhpfDZcLyJCEGMR9jAV3apJtvFtx9TVdhUPsAxjQ2pnJ)
driver-class-name: com.mysql.jdbc.Driver
url: PASS(szkFDG56WcAOzG2utv0m2aoAvNFH5g3DXz0o6joZjT26Y5WNA+1Z+pQFpyhFBokqOp2jsFtB+P9b3gB601rfas3dSfvS8Bgo3MyP1nojJgVp6gCVi+B/XUs0keXPn+pbX/19HrlUN1LeEweHS/LCRZslhWJCsIXTwZo1PlpXRv3Vyhf2OEzzKLm3mIAYj51CrEaN3w5cMiCESlwvKUhpAJVz/uXQJ1spLUAMuXCKKrXM/6dSRnWyTtdFRost5cChEU9uRjw5M+8HU3BLemtcK0vM8iYDjEi5zDbZtwxD3hA=)
type: com.alibaba.druid.pool.DruidDataSource

5. 總結

jasypt還有許多高級用法,比如可以自己配置加密算法,具體的操作可以參考Github上的文檔。

責任編輯:武曉燕 來源: 碼猿技術專欄
相關推薦

2022-06-06 08:42:04

spring-boo開發接口防盜刷

2020-06-22 07:55:28

接口爬蟲

2021-08-02 18:23:01

Spring隱私數據

2021-09-30 06:31:12

Spring Boot配置密碼

2024-04-23 14:13:38

開發配置文件

2009-06-17 14:10:30

Spring配置文件

2025-04-08 01:00:00

Spring開發系統

2025-02-26 08:03:17

SpringJPAMyBatis

2020-09-15 11:40:37

Spring Boot代碼Java

2023-11-01 08:30:20

SpringYAML

2011-01-21 15:08:45

Sendmail

2022-11-16 10:39:30

Spring配置文件生效

2025-01-26 00:00:40

微服務架構服務

2020-11-13 07:08:51

Spring Boot應用Spring

2020-09-27 14:13:50

Spring BootJava框架

2022-05-26 10:42:30

數據權限注解

2021-02-03 09:04:11

解密Spring配置

2024-05-31 14:04:18

2022-05-20 12:24:45

分庫分表Java依賴

2025-03-28 07:56:39

Spring服務配置
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 久久i| 国产精品视频一区二区三区不卡 | 久久久久久亚洲精品 | 日本中文在线视频 | 99国产精品一区二区三区 | 99热激情 | 伊人色综合久久久天天蜜桃 | 9久久婷婷国产综合精品性色 | 国精产品一区一区三区免费完 | 亚洲区一 | 亚洲精品大全 | 干一干操一操 | 亚洲欧美一区二区三区国产精品 | 99久久婷婷国产精品综合 | 精品国产91| 国产乱码精品一区二区三区av | 久久精品国产久精国产 | 免费看a| 国产精品爱久久久久久久 | 久久香焦 | 黄色免费网址大全 | 国产午夜精品一区二区三区在线观看 | 中文日韩字幕 | 天天摸天天干 | 91成人午夜性a一级毛片 | 色爱综合网| 欧美lesbianxxxxhd视频社区 | 尤物在线精品视频 | 中文字幕一区二区三区四区五区 | 爱爱无遮挡 | 日韩精品专区在线影院重磅 | 久久久久九九九九 | 精品福利在线视频 | 免费在线观看黄网站 | 午夜在线影院 | 81精品国产乱码久久久久久 | 久久久久久免费毛片精品 | 在线小视频 | 日韩av高清在线 | 精品国产乱码久久久久久88av | 日韩欧美在线不卡 |