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

springboot3 使用 jasypt 加密配置文件的使用步驟

 更新時(shí)間:2024年11月08日 10:35:57   作者:魯子狄  
在SpringBoot項(xiàng)目中,使用Jasypt加密配置文件可以有效保護(hù)敏感信息,首先,需添加Jasypt依賴并配置加密密碼,可在application.properties或通過啟動(dòng)參數(shù)、環(huán)境變量設(shè)置,本文介紹了Jasypt的配置步驟及使用方法,幫助開發(fā)者保護(hù)應(yīng)用配置信息

在線密碼生成器 : Most Reliable Online Password Generator | Free and Secure (getmypassword.com)

官網(wǎng) : jasypt

使用步驟 :

1. 添加依賴 :

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

2.配置加密密碼

Jasypt需要一個(gè)密碼來進(jìn)行加密和解密操作。可以通過以下幾種方式配置這個(gè)密碼:

在配置文件中指定 :在你的application.propertiesapplication.yml配置文件中,添加jasypt.encryptor.password配置項(xiàng),并設(shè)置你的密碼。例如:

# application.properties
jasypt.encryptor.password=your_encryption_password

或者,在application.yml中:

jasypt:
  encryptor:
    password: your_encryption_password

然而,將密碼直接寫在配置文件中可能存在安全風(fēng)險(xiǎn)。因此,更推薦的做法是通過啟動(dòng)參數(shù)或環(huán)境變量來傳遞這個(gè)密碼。

  • 通過啟動(dòng)參數(shù)指定:在啟動(dòng)應(yīng)用程序時(shí),可以通過

-Djasypt.encryptor.password=your_encryption_password參數(shù)來指定加密密碼。

使用環(huán)境變量:在某些情況下,使用環(huán)境變量來存儲(chǔ)敏感信息(如加密密碼)可能更為安全。具體方法取決于你的應(yīng)用程序部署環(huán)境。

3. 加密敏感信息

在配置加密密碼后,你可以使用Jasypt提供的工具或API來加密你的敏感信息。加密后的信息將以密文形式存儲(chǔ)。

使用Jasypt CLI工具:Jasypt提供了一個(gè)命令行界面(CLI)工具,允許你在命令行中加密和解密字符串。你需要下載Jasyptjar包,并在命令行中運(yùn)行相應(yīng)的命令。

Jasypt JAR 文件下載地址 :

jasypt-1.9.3.jar

生成密鑰

使用 Jasypt 提供的命令行工具生成密鑰。

java -cp jasypt-1.9.3.jar org.jasypt.intf.cli.JasyptPBEStringEncryptionCLI input="your-strong-password" password="your-secret-key" algorithm=PBEWithMD5AndTripleDES
  • input:你要加密的字符串,例如數(shù)據(jù)庫連接字符串、用戶名、密碼等。
  • password:用于加密的密鑰。
  • algorithm:加密算法,推薦使用 PBEWITHHMACSHA512ANDAES_256。

使用Jasypt API :在你的Java應(yīng)用程序中,你可以通過注入StringEncryptor接口的實(shí)現(xiàn)類來編程方式加密和解密字符串。這通常在你的Spring Boot應(yīng)用程序中通過自動(dòng)裝配完成。

/**
 * 加密控制器
 *
 * @author 魯子狄
 **/
@SaIgnore
@RequiredArgsConstructor
@RestController
@RequestMapping("/jasypt")
public class JasyptController {
    private final StringEncryptor stringEncryptor;
    /**
     * 加密
     *
     * @param text 明文
     * @return 密文
     */
    @RequestMapping("/encrypt")
    public String encrypt(String text) {
        return stringEncryptor.encrypt(text);
    }
    /**
     * 解密
     *
     * @param text 密文
     * @return 明文
     */
    @RequestMapping("/decrypt")
    public String decrypt(String text) {
        return stringEncryptor.decrypt(text);
    }
}

4. 將加密信息存儲(chǔ)到配置文件中

密鑰格式如下:

ENC(your-encrypted-string)

加密敏感信息后,你需要將這些加密后的信息存儲(chǔ)到配置文件中。在Jasypt中,加密后的信息通常以ENC(...)的形式出現(xiàn),括號(hào)內(nèi)是加密后的密文。例如:

username: ENC(aHApYu/25KrMl/q6Mr7X+0jYRC8E52V62ciUqtzDelELeHUwUrgGDl1oQJVUeXCt)
password: ENC(A0bDpXcWODFJ7JXiDNVKU5n49RSLM4Q3e5ZtS5T+fTY54S12zazVyxHhbV49OzY7)

5.應(yīng)用程序啟動(dòng)時(shí)自動(dòng)解密

當(dāng)你的Spring Boot應(yīng)用程序啟動(dòng)時(shí),Jasypt會(huì)自動(dòng)檢測(cè)配置文件中的ENC(...)字符串,并使用你配置的加密密碼來解密這些字符串。解密后的明文將用于應(yīng)用程序的配置中。

注意: 如過用環(huán)境變量傳參,本地啟動(dòng)時(shí)需要傳入環(huán)境變量,jar包運(yùn)行也一樣

-Djasypt.encryptor.password=your-encryptor-password

本地

jar包命令 :

java -Djasypt.encryptor.password=your-encryptor-password -jar your-jar
配置參數(shù)描述示例
jaspyt.encryptor.password加密器的密碼,用于解密屬性jaspyt.encryptor.password=mySecretPassword
jaspyt.encryptor.algorithm加密算法的名稱jaspyt.encryptor.algorithm=PBEWithMD5AndDES
jaspyt.encryptor.keyObtentionIterations獲取密鑰時(shí)使用的迭代次數(shù)jaspyt.encryptor.keyObtentionIterations=1000
jaspyt.encryptor.poolSize加密池的大?。ㄈ绻褂昧顺鼗用芷鳎?/td>jaspyt.encryptor.poolSize=1
jaspyt.encryptor.providerName加密提供者的名稱(如JCE提供者)jaspyt.encryptor.providerName=SunJCE
jaspyt.encryptor.saltGeneratorClassName鹽生成器的類名jaspyt.encryptor.saltGeneratorClassName=org.jasypt.salt.RandomSaltGenerator
jaspyt.encryptor.ivGeneratorClassName初始向量生成器的類名jaspyt.encryptor.ivGeneratorClassName=org.jasypt.iv.NoIvGenerator
jaspyt.encryptor.stringOutputType加密字符串的輸出類型(如base64)jaspyt.encryptor.stringOutputType=base64
jaspyt.encryptor.property.prefix加密屬性前綴,用于識(shí)別加密屬性jaspyt.encryptor.property.prefix=ENC(
jaspyt.encryptor.property.suffix加密屬性后綴,用于識(shí)別加密屬性jaspyt.encryptor.property.suffix=)
jaspyt.encryptor.proxyPropertySources是否通過代理截取屬性值以進(jìn)行解密jaspyt.encryptor.proxyPropertySources=true

支持的加密算法

Jasypt支持多種加密算法以保護(hù)敏感數(shù)據(jù)。以下是Jasypt支持的一些常見加密算法:

加密算法名稱描述
PBEWithMD5AndDES基于密碼的加密(PBE),使用MD5作為散列函數(shù)和DES作為加密算法。這是一種較舊的加密算法,但在某些舊系統(tǒng)中可能仍在使用
PBEWithMD5AndTripleDES與PBEWithMD5AndDES類似,但使用TripleDES作為加密算法,提供了更強(qiáng)的安全性。
PBEWithHMACSHA512ANDAES_256使用HMAC-SHA-512散列函數(shù)和AES-256加密算法的組合,提供了非常高的安全性。這是Jasypt較新版本中推薦的加密算法之一(默認(rèn)值)
AES高級(jí)加密標(biāo)準(zhǔn)(AES),是一種廣泛使用的對(duì)稱加密算法。Jasypt支持不同長(zhǎng)度的AES密鑰,如AES-128、AES-192和AES-256
RSARivest-Shamir-Adleman(RSA)算法,是一種非對(duì)稱加密算法。它使用一對(duì)密鑰:公鑰用于加密數(shù)據(jù),私鑰用于解密數(shù)據(jù)

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

相關(guān)文章

  • Java移動(dòng)文件夾及其所有子文件與子文件夾

    Java移動(dòng)文件夾及其所有子文件與子文件夾

    這篇文章主要為大家詳細(xì)介紹了Java移動(dòng)文件夾及其所有子文件與子文件夾的方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-03-03
  • springboot的pom.xml配置方式

    springboot的pom.xml配置方式

    這篇文章主要介紹了springboot的pom.xml配置方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • SpringBoot中@ConfigurationProperties 配置綁定

    SpringBoot中@ConfigurationProperties 配置綁定

    本文主要介紹了SpringBoot中@ConfigurationProperties 配置綁定,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-11-11
  • 配置Servlet兩種方法以及特點(diǎn)詳解

    配置Servlet兩種方法以及特點(diǎn)詳解

    這篇文章主要介紹了配置Servlet兩種方法以及特點(diǎn)詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-03-03
  • MyBatis處理枚舉類型的方法詳解

    MyBatis處理枚舉類型的方法詳解

    MyBatis 處理枚舉類型的機(jī)制相對(duì)直接,它提供了一種靈活的方式來處理Java枚舉(enum)類型和數(shù)據(jù)庫之間的映射,本文給大家介紹了MyBatis處理枚舉類型的兩種方法,需要的朋友可以參考下
    2024-07-07
  • Mybatis調(diào)用MySQL存儲(chǔ)過程的簡(jiǎn)單實(shí)現(xiàn)

    Mybatis調(diào)用MySQL存儲(chǔ)過程的簡(jiǎn)單實(shí)現(xiàn)

    本篇文章主要介紹了Mybatis調(diào)用MySQL存儲(chǔ)過程的簡(jiǎn)單實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。
    2017-04-04
  • Spring?Boot如何配置yml配置文件定義集合、數(shù)組和Map

    Spring?Boot如何配置yml配置文件定義集合、數(shù)組和Map

    這篇文章主要介紹了Spring?Boot?優(yōu)雅配置yml配置文件定義集合、數(shù)組和Map,包括Spring?Boot?yml配置文件定義基本數(shù)據(jù)類型和引用數(shù)據(jù)類型的方式,需要的朋友可以參考下
    2023-10-10
  • 深度解析SpringBoot中@Async引起的循環(huán)依賴

    深度解析SpringBoot中@Async引起的循環(huán)依賴

    本文主要介紹了深度解析SpringBoot中@Async引起的循環(huán)依賴,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-02-02
  • SpringBoot詳細(xì)講解通過自定義classloader加密保護(hù)class文件

    SpringBoot詳細(xì)講解通過自定義classloader加密保護(hù)class文件

    這篇文章主要介紹了SpringBoot通過自定義classloader加密class文件,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-04-04
  • mybatis和mybatisplus批量插入問題示例詳解

    mybatis和mybatisplus批量插入問題示例詳解

    最近在處理一個(gè)功能的時(shí)候,需要批量插入數(shù)據(jù),這篇文章主要給大家介紹了關(guān)于mybatis和mybatisplus批量插入問題的相關(guān)資料,文中通過實(shí)例代碼介紹非常詳細(xì),需要的朋友可以參考下
    2023-04-04

最新評(píng)論