SpringBoot配置文件敏感信息加密-jasypt


使用過SpringBoot配置文件的朋友都知道,資源文件中的內容通常情況下是明文顯示,安全性就比較低一些。打開application.properties或application.yml,比如mysql登陸密碼,redis登陸密碼以及第三方的密鑰等等一覽無余,這里介紹一個加解密組件,提高一些屬性配置的安全性。

jasypt由一個國外大神寫的一個springboot下的工具包。Git地址:https://github.com/ulisesbocchio/jasypt-spring-boot

直接上代碼:

1、pom文件中增加依賴:

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

2、application.yml文件中增加jasypt的秘鑰(該秘鑰自定義的):

jasypt:
  encryptor:
    #加密秘鑰
    password: EbfYkitulv73I2p0mXI50JMXoaxZTKJ7

3、測試類:

@RestController
public class IndexController {

    @Autowired
    private StringEncryptor encryptor;

    /**
     * 測試jasypt加密解密
     */
    @GetMapping("/jasypt")
    public void testJasypt() {
        String password = "123456";
        String encryptPwd = encryptor.encrypt(password);
        System.out.println("加密::" + encryptPwd);
        System.out.println("解密:" + encryptor.decrypt(encryptPwd));
    }

}

4、啟動服務,在控制台可以看到jaspyt的默認配置(比如加密方式是PBEWithMD5AndDES):

5、在瀏覽器請求(端口號自定義):http://localhost:18081/jasypt ,在控制台打印信息:

加密: stqvirrvG8TcLz9mqflBDQ==
解密:123456

jasypt由於其使用的是PBEWithMD5AndDES加密方式,所以每次加密出來的結果都不一樣,但是解密都是一樣的,所以很適合對數據進行加密

6、將加密的結果替換配置文件中的敏感字段(這里以數據庫密碼為例,數據庫密碼是123456):

spring:
  application:
    name: service-provider
  datasource: 
    driver-class-name: com.mysql.jdbc.Driver
    type: com.alibaba.druid.pool.DruidDataSource
    url: jdbc:mysql://localhost:3306/mydb?autoReconnect=true&failOverReadOnly=false&createDatabaseIfNotExist=true&useSSL=false&useUnicode=true&characterEncoding=utf8
    username: root
    password: ENC(stqvirrvG8TcLz9mqflBDQ==)

上面的 ENC()是固定寫法,()里面是加密后的信息。

7、在測試類中增加代碼:

    @Value("${spring.datasource.password}")
    private String dbPassword; // 數據庫密碼

    /**
     * 測試配置文件字段加密后,項目中該字段的值
     */
    @GetMapping("/password")
    public String password() {
        return dbPassword;
    } 

請求http://localhost:18081/password,會發現結果是123456,說明直接將加密文件解密出來了

 

擴展

a、自定義上面第6點中ENC()的固定寫法。在配置文件中增加jasypt.encryptor.property:

jasypt:
  encryptor:
    #加解密秘鑰
    password: EbfYkitulv73I2p0mXI50JMXoaxZTKJ7
    #設置前綴后綴
    property: prefix: "ENC@["
      suffix: "]"
    

b、將加解密秘鑰放在配置文件中是不安全的,有如下幾種解決辦法:

1、在啟動類上賦值秘鑰:

@SpringBootApplication
public class ProviderApplication {

    public static void main(String[] args) {
        /** 配置加解密秘鑰,與配置文件的密文分開放 */
        System.setProperty("jasypt.encryptor.password", "travel-app");
//        System.setProperty("jasypt.encryptor.password", "EbfYkitulv73I2p0mXI50JMXoaxZTKJ7");

        SpringApplication.run(ProviderApplication.class, args);
    }

}

2、自定義StringEncryptor:

/**
     * 配置StringEncryptor
     */
    @Bean("jasyptStringEncryptor")
    public StringEncryptor stringEncryptor() {
        PooledPBEStringEncryptor encryptor = new PooledPBEStringEncryptor();
        SimpleStringPBEConfig config = new SimpleStringPBEConfig();
        config.setPassword("EbfYkitulv73I2p0mXI50JMXoaxZTKJ7");
        config.setAlgorithm("PBEWithMD5AndDES");
        config.setKeyObtentionIterations("1000");
        config.setPoolSize("1");
        config.setProviderName("SunJCE");
        config.setSaltGeneratorClassName("org.jasypt.salt.RandomSaltGenerator");
        config.setIvGeneratorClassName("org.jasypt.salt.NoOpIVGenerator");
        config.setStringOutputType("base64");
        encryptor.setConfig(config);
        return encryptor;
    }

3、使用jar的方式啟動

 

 

踩過的坑

a、必須配置加解密用的秘鑰,即jasypt.encryptor.password,不然啟動會報錯

b、springboot2.x以下的版本,只能用jasypt1.x的版本。如果用jasypt2.x的版本,啟動會報錯,詳見https://github.com/ulisesbocchio/jasypt-spring-boot/issues/97

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM