欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

SpringBoot使用Jasypt對(duì)配置文件和數(shù)據(jù)庫(kù)密碼加密

 更新時(shí)間:2024年02月28日 09:57:04   作者:skywsp  
在做數(shù)據(jù)庫(kù)敏感信息保護(hù)時(shí),應(yīng)加密存儲(chǔ),本文就來(lái)介紹一下SpringBoot使用Jasypt對(duì)配置文件和數(shù)據(jù)庫(kù)密碼加密,具有一定的參考價(jià)值,感興趣的可以了解一下

在做數(shù)據(jù)庫(kù)敏感信息保護(hù)時(shí),Web應(yīng)用配置的賬號(hào)密碼,在配置文件應(yīng)加密存儲(chǔ),禁止使用明文賬號(hào)密碼,這時(shí)我們可以使用Jasypt加密來(lái)實(shí)現(xiàn)需求。

一、Jasypt簡(jiǎn)介

Jasypt是一個(gè)Java簡(jiǎn)易加密庫(kù),用于加密配置文件中的敏感信息,如數(shù)據(jù)庫(kù)密碼。jasypt庫(kù)與springboot集成,在實(shí)際開(kāi)發(fā)中非常方便。

1、Jasypt Spring Boot 為 spring boot 應(yīng)用程序中的屬性源提供加密支持,出于安全考慮,Spring boot 配置文件中的敏感信息通常需要對(duì)它進(jìn)行加密/脫敏處理,盡量不使用明文,要實(shí)現(xiàn)這一點(diǎn),辦法有很多,自己手動(dòng)對(duì)敏感信息進(jìn)行加解密也是可以的。

2、在程序界有需求就有人奉獻(xiàn),Jasypt 開(kāi)源安全框架就是專(zhuān)門(mén)用于處理 Spring boot 屬性加密的,在配置文件中使用特定格式直接配置密文,然后應(yīng)用啟動(dòng)的時(shí)候,Jasypt 會(huì)自動(dòng)將密碼解密成明文供程序使用。

1)Jasypt 加密屬性配置格式:

spring:
  datasource:
    password: ENC(o6L5p3ymfSMiscyR9CPio4NfGPg+W9==)

ENC() 就是它的標(biāo)識(shí),程序啟動(dòng)的時(shí)候,會(huì)自動(dòng)解密其中的內(nèi)容,如果解密失敗,則會(huì)報(bào)錯(cuò)。
2)所以獲取這些屬性值和平時(shí)沒(méi)有區(qū)別,直接使用如 @Value(“${spring.datasource.password}”) 獲取即可,取值并不需要特殊處理。

3、jasypt 同一個(gè)密鑰(secretKey)對(duì)同一個(gè)內(nèi)容執(zhí)行加密,每次生成的密文都是不一樣的,但是根據(jù)根據(jù)這些密文解密成原內(nèi)容都是可以的.

4、Jasypt 官方使用文檔:http://www.jasypt.org/
GitHub地址:https://github.com/ulisesbocchio/jasypt-spring-boot。

二、集成方法

官網(wǎng)上推薦的集成到SpringBoot項(xiàng)目中,有3種方法分別是:

  • 如果使用@SpringBootApplication或@EnableAutoConfiguration,則僅需要添加jasypt-spring-boot-starter啟動(dòng)器jar到您的類(lèi)路徑中即可,它自動(dòng)會(huì)在整個(gè) Spring 環(huán)境中啟用可加密屬性。
  • 添加jasypt-spring-boot到您的類(lèi)路徑并添加@EnableEncryptableProperties到您的主配置類(lèi)以在整個(gè) Spring 環(huán)境中啟用可加密屬性。
  • 添加jasypt-spring-boot到您的類(lèi)路徑并使用@EncrytablePropertySource注解聲明單獨(dú)的可加密屬性源。

2.1 方式一

在Springboot應(yīng)用程序中,如果使用了@SpringBootApplication 或者@EnableAutoConfiguration注解,則可以在pom文件中添加jasypt-spring-boot-starter依賴,然后就可以在整個(gè)Spring環(huán)境中使用jasypt對(duì)屬性進(jìn)行加解密操作(屬性包括:系統(tǒng)屬性、環(huán)境屬性、命令行參數(shù)、application.properties、application-*.properties、yml屬性以及任何其他屬性源)。

<dependency>
	<groupId>com.github.ulisesbocchio</groupId>
	<artifactId>jasypt-spring-boot-starter</artifactId>
    <!-- JDK9+用3.x版本,JDK8用2.x版本 -->
    <!-- 倉(cāng)庫(kù):https://repo1.maven.org/maven2/com/github/ulisesbocchio/jasypt-spring-boot-starter/ -->
	<version>2.1.2</version>
</dependency>

2.2 方式二

如果項(xiàng)目中沒(méi)有使用到@SpringBootApplication 或者@EnableAutoConfiguration 自動(dòng)配置注解,則可以通過(guò)以下兩個(gè)步驟完成對(duì)Jasypt的集成。

步驟一:pom文件引入jasypt-spring-boot依賴

<dependency>
	<groupId>com.github.ulisesbocchio</groupId>
	<artifactId>jasypt-spring-boot</artifactId>
    <!-- JDK9+用3.x版本,JDK8用2.x版本 -->
    <!-- 倉(cāng)庫(kù):https://repo1.maven.org/maven2/com/github/ulisesbocchio/jasypt-spring-boot-starter/ -->
	<version>2.1.2</version>
</dependency>

步驟二:在配置類(lèi)中,添加@EnableEncryptableProperties注解,示例如下:

import com.ulisesbocchio.jasyptspringboot.annotation.EnableEncryptableProperties;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.SpringApplication;

@SpringBootApplication
@EnableEncryptableProperties
public class MySpringBootApp {
    public static void main(String[] args) {
        SpringApplication.run(MySpringBootApp.class, args);
    }
}

通過(guò)這種方式,你的項(xiàng)目一樣可以集成Jasypt,并且可加密屬性也可以在整個(gè)Spring環(huán)境中啟用屬性包括:系統(tǒng)屬性、環(huán)境屬性、命令行參數(shù)、application.properties、application-*.properties、yml屬性以及任何其他屬性源)。

2.3 方式三

如果項(xiàng)目中沒(méi)有使用到@SpringBootApplication 或者@EnableAutoConfiguration 自動(dòng)配置注解,又不想在整個(gè)Spring環(huán)境中啟用加密的屬性,則可以使用該種方式,具體步驟如下:

步驟一:pom文件引入jasypt-spring-boot依賴

<dependency>
	<groupId>com.github.ulisesbocchio</groupId>
	<artifactId>jasypt-spring-boot</artifactId>
    <!-- JDK9+用3.x版本,JDK8用2.x版本 -->
    <!-- 倉(cāng)庫(kù):https://repo1.maven.org/maven2/com/github/ulisesbocchio/jasypt-spring-boot-starter/ -->
	<version>2.1.2</version>
</dependency>

步驟二、在配置類(lèi)中,使用@EncryptablePropertySource注解添加任意數(shù)量想要生效加密屬性的配置文件路徑,與Spring中@PropertySource注解的使用類(lèi)似,示例如下:

@Configuration
@EncryptablePropertySource(name = "EncryptedProperties", value = "classpath:encrypted.properties")
public class MyApplication {
    ...
}

同時(shí),還可以使用@EncryptablePropertySources 注解對(duì)@EncryptablePropertySource配置進(jìn)行分組,示例如下:

@Configuration
@EncryptablePropertySources({@EncryptablePropertySource("classpath:encrypted.properties"),
                             @EncryptablePropertySource("classpath:encrypted2.properties")})
public class MyApplication {
    ...
}

說(shuō)明:從Jasypt 1.8版本開(kāi)始,@EncryptablePropertySource注解支持配置YAML文件。

三、Springboot整合Jasypt實(shí)戰(zhàn)

Dmo源碼請(qǐng)點(diǎn)這里!

3.1 引入依賴

本Demo使用JDK8,所有依賴2.1.2版本

    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
            <version>2.3.4.RELEASE</version>
        </dependency>
        <dependency>
            <groupId>com.github.ulisesbocchio</groupId>
            <artifactId>jasypt-spring-boot-starter</artifactId>
            <version>2.1.2</version>
        </dependency>
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>

3.2 準(zhǔn)備加密后的數(shù)據(jù)

    @Test
    public void test() {
        BasicTextEncryptor textEncryptor = new BasicTextEncryptor();

        // 加密秘鑰(鹽值)
        textEncryptor.setPassword("jasyptSalt123");

        // 對(duì)賬號(hào)加密
        String encUsername = textEncryptor.encrypt("zhangsan");
        System.out.println(encUsername);

        // 對(duì)密碼加密
        String encPassword = textEncryptor.encrypt("abc123@test");
        System.out.println(encPassword);
    }

3.3 配置文件使用加密數(shù)據(jù)

spring:
  datasource:
    # 明文賬號(hào)密碼
    username: zhangsan
    password: abc123@test

    # 加密后的賬號(hào)密碼
    encUsername: ENC(CsXfWspTjwzJ99zeeXhNAk7Jk0/XbeTp)
    encPassword: ENC(SZqTzbJYCOCErUYWDHdSrXC1Mb/wNYSB)

# jasypt加密秘鑰,需要從配置文件中刪除,改為在項(xiàng)目啟動(dòng)命令上配置環(huán)境參數(shù)
jasypt:
  encryptor:
    password: jasyptSalt123

3.4 直接獲取解密數(shù)據(jù)

@Component
@ConfigurationProperties(prefix = "spring.datasource")
public class SamProperties {
    private String username;
    private String password;

    // 配置注入前會(huì)自動(dòng)解密
    private String encUsername;
    private String encPassword;
}

四、拓展

4.1 關(guān)于加解密秘鑰如何存儲(chǔ)

如果秘鑰寫(xiě)在代碼或者配置文件,一旦代碼泄露,那別人就可以使用秘鑰解密我們的密文,這樣對(duì)敏感信息加密的作用就不存在了,因此,秘鑰不能以明文形式存儲(chǔ)在代碼或者配置文件中,應(yīng)該在應(yīng)用部署時(shí)通過(guò)變量傳入。

java -Djasypt.encryptor.password=秘鑰 -jar xxx.jar

或:

java -jar xxx.jar --jasypt.encryptor.password=秘鑰

4.2 使用jasypt3.0啟動(dòng)時(shí)報(bào)

使用jasypt3.0啟動(dòng)時(shí)報(bào):Failed to bind properties under ‘xxx.xxx.xxx’ to java.lang.String

官方描述,3.0后默認(rèn)支持的算法為PBEWITHHMACSHA512ANDAES_256 ,該種加密方式由sha512 加 AES 高級(jí)加密組成,需要JDK1.9以上支持或者添加JCE(Java Cryptography Extension無(wú)限強(qiáng)度權(quán)限策略文件)支持,否則運(yùn)行會(huì)出現(xiàn)錯(cuò)誤。

4.2.1 解決方案1,降低版本
降低jasypt的版本 - 使用2.x的版本

4.2.2 解決方案2,修改算法
將加密算法替換成PBEWithMD5AndDES 算法,并配置iv-generator-classname: 為org.jasypt.iv.NoIvGenerator值

到此這篇關(guān)于SpringBoot使用Jasypt對(duì)配置文件和數(shù)據(jù)庫(kù)密碼加密的文章就介紹到這了,更多相關(guān)SpringBoot Jasypt加密內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • MyBatis入門(mén)學(xué)習(xí)教程-MyBatis快速入門(mén)

    MyBatis入門(mén)學(xué)習(xí)教程-MyBatis快速入門(mén)

    MyBatis是一個(gè)支持普通SQL查詢,存儲(chǔ)過(guò)程和高級(jí)映射的優(yōu)秀持久層框架,這篇文章主要給大家分享MyBatis的一篇快速入門(mén)教程
    2021-06-06
  • SpringMVC中處理靜態(tài)資源的過(guò)程詳解

    SpringMVC中處理靜態(tài)資源的過(guò)程詳解

    本文給大家介紹SpringMVC中處理靜態(tài)資源的過(guò)程,結(jié)合示例代碼給大家講解的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧
    2023-11-11
  • 深入解析Java中的Class Loader類(lèi)加載器

    深入解析Java中的Class Loader類(lèi)加載器

    這篇文章主要介紹了Java中的類(lèi)加載器,是Java入門(mén)學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下
    2016-03-03
  • java中的Consumer、Supply如何實(shí)現(xiàn)多參數(shù)?

    java中的Consumer、Supply如何實(shí)現(xiàn)多參數(shù)?

    Java的Consumer接口只能接受一個(gè)參數(shù),但可以通過(guò)自定義接口、使用Tuple或嵌套結(jié)構(gòu)來(lái)實(shí)現(xiàn)對(duì)多個(gè)參數(shù)的處理,對(duì)于Supplier接口,它不能接受參數(shù),但可以通過(guò)自定義BiSupplier、結(jié)合Function或封裝參數(shù)為對(duì)象來(lái)實(shí)現(xiàn)對(duì)兩個(gè)參數(shù)并返回一個(gè)值的功能
    2024-11-11
  • JAVA如何獲取工程下的文件

    JAVA如何獲取工程下的文件

    這篇文章主要介紹了JAVA如何獲取工程下的文件,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-08-08
  • selenium-java實(shí)現(xiàn)自動(dòng)登錄跳轉(zhuǎn)頁(yè)面方式

    selenium-java實(shí)現(xiàn)自動(dòng)登錄跳轉(zhuǎn)頁(yè)面方式

    利用Selenium和Java語(yǔ)言可以編寫(xiě)一個(gè)腳本自動(dòng)刷新網(wǎng)頁(yè),首先,需要確保Google瀏覽器和Chrome-Driver驅(qū)動(dòng)的版本一致,通過(guò)指定網(wǎng)站下載對(duì)應(yīng)版本的瀏覽器和驅(qū)動(dòng),在Maven項(xiàng)目中添加依賴,編寫(xiě)腳本實(shí)現(xiàn)網(wǎng)頁(yè)的自動(dòng)刷新,此方法適用于需要頻繁刷新網(wǎng)頁(yè)的場(chǎng)景,簡(jiǎn)化了操作,提高了效率
    2024-11-11
  • kaptcha驗(yàn)證碼使用方法詳解

    kaptcha驗(yàn)證碼使用方法詳解

    這篇文章主要為大家詳細(xì)介紹了kaptcha驗(yàn)證碼的使用方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-12-12
  • Java Web 實(shí)現(xiàn)QQ登錄功能一個(gè)帳號(hào)同一時(shí)間只能一個(gè)人登錄

    Java Web 實(shí)現(xiàn)QQ登錄功能一個(gè)帳號(hào)同一時(shí)間只能一個(gè)人登錄

    對(duì)于一個(gè)帳號(hào)在同一時(shí)間只能一個(gè)人登錄,下文給大家介紹的非常詳細(xì),對(duì)java web qq 登錄功能感興趣的朋友一起看看吧
    2016-11-11
  • Java技巧函數(shù)方法實(shí)現(xiàn)二維數(shù)組遍歷

    Java技巧函數(shù)方法實(shí)現(xiàn)二維數(shù)組遍歷

    這篇文章主要介紹了Java技巧函數(shù)方法實(shí)現(xiàn)二維數(shù)組遍歷,二維數(shù)組遍歷,每個(gè)元素判斷下是否為偶數(shù),相關(guān)內(nèi)容需要的小伙伴可以參考一下
    2022-08-08
  • Spring Boot定時(shí)任務(wù)的使用方法

    Spring Boot定時(shí)任務(wù)的使用方法

    這篇文章為大家詳細(xì)主要介紹了Spring Boot定時(shí)任務(wù)的使用方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-08-08

最新評(píng)論