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

SpringBoot+ENC實(shí)現(xiàn)密鑰加密的使用示例

 更新時(shí)間:2024年07月29日 09:40:39   作者:一恍過去  
本文主要介紹了SpringBoot+ENC實(shí)現(xiàn)密鑰加密的使用示例,主要是為了將配置信息從應(yīng)用程序代碼中分離出來(lái),以提高安全性和可維護(hù)性,感興趣的可以了解一下

前言

Spring Boot中使用ENC(Environment-Neutral Configuration)主要是為了將配置信息從應(yīng)用程序代碼中分離出來(lái),以提高安全性和可維護(hù)性。ENC的主要優(yōu)點(diǎn)包括:

  • 安全性增強(qiáng): 敏感信息(如數(shù)據(jù)庫(kù)密碼、API密鑰等)不應(yīng)硬編碼在代碼中,而是應(yīng)該使用加密的方式存儲(chǔ)在配置文件中,然后通過ENC進(jìn)行解密和使用,從而減少泄露風(fēng)險(xiǎn)。
  • 可維護(hù)性: 將配置信息與代碼分離,使得配置可以獨(dú)立地修改和管理,而不需要重新編譯和部署應(yīng)用程序。這樣可以降低維護(hù)成本,并使應(yīng)用程序更易于管理。
  • 靈活性: 使用ENC可以根據(jù)不同的環(huán)境(開發(fā)、測(cè)試、生產(chǎn)等)提供不同的配置,而不需要修改應(yīng)用程序代碼,從而提高了部署的靈活性和可移植性。

1、整合SpringBoot

1.1、POM

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

1.2、加密鹽值配置

整合SpringBoot時(shí),鹽值的配置最好式寫到配置中心的文件中,鹽值寫到本地文件,泄露后也容易被進(jìn)行解密

jasypt:
  encryptor:
  	# password值任意,最好隨機(jī)字符
    password: hhX4FzbwcT

1.3、工具類使用

使用工具類對(duì)需要處理的明文數(shù)據(jù)進(jìn)行加密處理,再將加密結(jié)果寫入到配置文件中

注意:工具類使用完成后,應(yīng)該刪除加密鹽

import org.jasypt.encryption.pbe.StandardPBEStringEncryptor;

public class JasyptTest {

    /**
     * 加密鹽值,使用完成后進(jìn)行刪除,或者不能提交到`生產(chǎn)環(huán)境`,比如:
     */
    private final static String PASSWORD = "hhX4FzbwcT";


    public static void main(String[] args) {

        PooledPBEStringEncryptor encryptor = new PooledPBEStringEncryptor();

        SimpleStringPBEConfig config = new SimpleStringPBEConfig();
        // 用于設(shè)置加密密鑰。密鑰是用于加密和解密字符串的關(guān)鍵信息。
        config.setPassword(PASSWORD);
        // 加密算法的名稱,jasypt-3.0.5版本后默認(rèn)的加密方式
        config.setAlgorithm("PBEWITHHMACSHA512ANDAES_256");
        // 用于設(shè)置加密時(shí)迭代次數(shù)的數(shù)量,增加迭代次數(shù)可以使攻擊者更難進(jìn)行密碼破解。
        config.setKeyObtentionIterations("1000");
        // 加密器池的大小。池是一組加密器實(shí)例,可確保加密操作的并發(fā)性。
        config.setPoolSize("1");
        // 用于設(shè)置JCE(Java Cryptography Extension)提供程序的名稱。
        config.setProviderName("SunJCE");
        // 用于設(shè)置生成鹽的類名稱。在此配置中,我們使用了org.jasypt.salt.RandomSaltGenerator,表示使用隨機(jī)生成的鹽。
        config.setSaltGeneratorClassName("org.jasypt.salt.RandomSaltGenerator");
        // 用于設(shè)置Jasypt使用的初始化向量(IV)生成器的類名。初始化向量是在加密過程中使用的一個(gè)固定長(zhǎng)度的隨機(jī)數(shù),用于加密數(shù)據(jù)塊,使每個(gè)數(shù)據(jù)塊的加密結(jié)果都是唯一的。在此配置中,我們使用了org.jasypt.iv.RandomIvGenerator類,該類是一個(gè)隨機(jī)生成器,用于生成實(shí)時(shí)隨機(jī)IV的實(shí)例。這樣可以確保每次加密的IV都是唯一的,從而增加加密強(qiáng)度。
        config.setIvGeneratorClassName("org.jasypt.iv.RandomIvGenerator");
        // 指定加密輸出類型。在此配置中,我們選擇了base64輸出類型。
        config.setStringOutputType("base64");
        encryptor.setConfig(config);

        // 明文1
        String name_encrypt = "root";
        // 明文2
        String password_encrypt = "123456";

        // 明文加密
        String encrypt1 = encryptor.encrypt(name_encrypt);
        String encrypt2 = encryptor.encrypt(password_encrypt);
        System.out.println("明文加密1:" + encrypt1);
        System.out.println("明文加密2:" + encrypt2);

        // 密文解密
        String decrypt1 = encryptor.decrypt(encrypt1);
        String decrypt2 = encryptor.decrypt(encrypt2);
        System.out.println("密文解密1:" + decrypt1);
        System.out.println("密文解密2:" + decrypt2);
    }
}

在這里插入圖片描述

1.4、加密配置使用

YAML:

sys:
 name: ENC(Yt36hceu3xGXEzrz2jCPjvalaXQ5yIHE04SVT6lIkcktrxqtBZrlivkAkA9/9oZ2)
 password: ENC(0Ci6irPOko9IG+hBZJAGoguIuE52gF/XiigCV4DwLm6NfkoyvV4Etgc9FzKK3MYl)

1.5、測(cè)試

項(xiàng)目成功啟動(dòng),Yaml中設(shè)置密文文本,Controller正常打印明文信息,就表示ENC配置成功了

@RestController
public class TestController {

    @Value("${sys.name}")
    private String name;

    @Value("${sys.password}")
    private String password;

    @GetMapping("/test")
    public void test() {
        System.out.println("name = " + name);
        System.out.println("password = " + password);
    }
}

2、ENC加載原理

1、在jasypt-spring-boot-starter包的自動(dòng)配置類JasyptSpringBootAutoConfiguration中通過@Import注解引入了EnableEncryptablePropertiesConfiguration配置類,該類中environment參數(shù)儲(chǔ)存了yaml文件元數(shù)據(jù);

2、在postProcessBeanFactory方法中,調(diào)用environment.getPropertySources()方法獲取yaml配置項(xiàng)目;

在這里插入圖片描述

3、通過convertPropertySources進(jìn)行數(shù)據(jù)轉(zhuǎn)換,修改yaml中配置項(xiàng)值,具體實(shí)現(xiàn)為調(diào)用instantiatePropertySource()方法,在該方法中,匹配propertySource instanceof MapPropertySource,轉(zhuǎn)化為EncryptableMapPropertySourceWrapper對(duì)象;

在這里插入圖片描述

在這里插入圖片描述

在這里插入圖片描述

在這里插入圖片描述

在這里插入圖片描述

4、EncryptableMapPropertySourceWapper類中,通過getProperty(name)方法進(jìn)行匹配,匹配成功后調(diào)用resolver.resolvePropertyValue進(jìn)行ENC配置的解密并且替換原有的propertySource值;

在這里插入圖片描述

到此這篇關(guān)于SpringBoot+ENC實(shí)現(xiàn)密鑰加密的使用示例的文章就介紹到這了,更多相關(guān)SpringBoot ENC密鑰加密內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • mybatis配置mapper-locations的坑及解決

    mybatis配置mapper-locations的坑及解決

    這篇文章主要介紹了mybatis配置mapper-locations的坑及解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-06-06
  • Java的垃圾強(qiáng)制回收實(shí)例分析

    Java的垃圾強(qiáng)制回收實(shí)例分析

    這篇文章主要介紹了Java的垃圾強(qiáng)制回收,結(jié)合實(shí)例形式分析了java垃圾強(qiáng)制回收的相關(guān)原理及實(shí)現(xiàn)方法,需要的朋友可以參考下
    2019-08-08
  • Spring IOC源碼剖析_如何整體認(rèn)知Spring體系結(jié)構(gòu)

    Spring IOC源碼剖析_如何整體認(rèn)知Spring體系結(jié)構(gòu)

    這篇文章主要介紹了Spring IOC源碼剖析_如何整體認(rèn)知Spring體系結(jié)構(gòu)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-09-09
  • Java枚舉詳解及使用實(shí)例(涵蓋了所有典型用法)

    Java枚舉詳解及使用實(shí)例(涵蓋了所有典型用法)

    這篇文章主要介紹了Java枚舉詳解及使用實(shí)例(涵蓋了所有典型用法),本文直接給出實(shí)例代碼,代碼中包含詳細(xì)注釋,需要的朋友可以參考下
    2015-05-05
  • 詳解Java中二分法的基本思路和實(shí)現(xiàn)

    詳解Java中二分法的基本思路和實(shí)現(xiàn)

    二分法是一個(gè)非常高效的算法,它常常用于計(jì)算機(jī)的查找過程中。本文將通過示例為大家詳細(xì)講講二分法的基本思路和實(shí)現(xiàn),感興趣的可以了解一下
    2022-08-08
  • idea創(chuàng)建maven項(xiàng)目速度慢的三種解決方案

    idea創(chuàng)建maven項(xiàng)目速度慢的三種解決方案

    這篇文章主要介紹了idea創(chuàng)建maven項(xiàng)目速度慢的三種解決方案,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來(lái)看看吧
    2019-01-01
  • Java中ArrayList類用法詳解

    Java中ArrayList類用法詳解

    這篇文章主要給大家介紹了關(guān)于Java中ArrayList類用法的相關(guān)資料,ArrayList是Java中的一種常見的數(shù)據(jù)結(jié)構(gòu),它實(shí)現(xiàn)了List接口,是線程不安全的動(dòng)態(tài)數(shù)組,需要的朋友可以參考下
    2023-09-09
  • SpringBoot@DeleteMapping(/xxx/{id})請(qǐng)求報(bào)405的解決

    SpringBoot@DeleteMapping(/xxx/{id})請(qǐng)求報(bào)405的解決

    這篇文章主要介紹了SpringBoot@DeleteMapping(/xxx/{id})請(qǐng)求報(bào)405的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-01-01
  • springCloud集成nacos啟動(dòng)時(shí)報(bào)錯(cuò)原因排查

    springCloud集成nacos啟動(dòng)時(shí)報(bào)錯(cuò)原因排查

    這篇文章主要介紹了springCloud集成nacos啟動(dòng)時(shí)報(bào)錯(cuò)原因排查,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • SpringBoot2整合activiti6環(huán)境搭建過程解析

    SpringBoot2整合activiti6環(huán)境搭建過程解析

    這篇文章主要介紹了SpringBoot2整合activiti6環(huán)境搭建過程解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-11-11

最新評(píng)論