springboot笔记示例八:yml文件数据库连接redis密码加密实现使用jasypt加密

springboot笔记示例八:yml文件数据库连接redis密码加密实现使用jasypt加密

本文md文件下载

https://download.csdn.net/download/a254939392/89496228

点击下载本文md文件

说明

springboot中大多数配置我们都采用yml文件配置,比如数据库连接,redis连接,等明文,存在安全风险,所以需要在yml文件中使用加密。本文采用开源jasypt加密实现该功能

pom引入

<!--2.1.1 与3版本默认算法有所改变-->
<dependency>
    <groupId>com.github.ulisesbocchio</groupId>
    <artifactId>jasypt-spring-boot-starter</artifactId>
    <version>3.0.5</version>
</dependency>

yml加密配置

> yml配置

```yaml
jasypt:
  encryptor:
    password: 123456 #salt盐值
    algorithm: PBEWithMD5AndDES #加密算法,3.x版本需要配置,2.x版本不需要配置
    iv-generator-classname: org.jasypt.iv.NoIvGenerator #固定配置
    
spring:
  application:
    name: xiaobao
  data:
    mongodb:
      host: 192.27.52.13
      port: 30010
      username: iot
      password: ENC(3mVqabPOmvndddddVQ22tpeUNkB01tFT) #需要机密的配置需要增加ENC前缀
      authentication-database: gas
      database: gas   

使用boot-starter 只需要pom依赖和yaml配置即可。

生成密钥工具类

package com.example.scengine.utils;

import org.jasypt.util.text.BasicTextEncryptor;

/**
 * jasypt-spring-boot-starter 生成密文的工具代码
 */
public class EncryptConfigUtil {
	public static String salt="123456";
    public static void main(String[] args) {
        String password = EncryptConfigUtil.jasyptEncrypt("root);
        String pwd = EncryptConfigUtil.jasyptDecrypt("3mVqabPOmvnXc7IFVQ22tpeUNkB01tFT");
    }

    /**
     * 加密
     *
     * @return
     */
    public static String jasyptEncrypt(String encryptString) {
        BasicTextEncryptor textEncryptor = new BasicTextEncryptor();
        //加密所需的salt
        textEncryptor.setPassword(salt);
        //要加密的数据(数据库的用户名或密码)
        String password = textEncryptor.encrypt(encryptString);
        System.out.println("加密后:" + password);
        return password;
    }

    /***
     * 解密
     * @param encryptString
     * @return
     */
    public static String jasyptDecrypt(String encryptString) {
        BasicTextEncryptor textEncryptor = new BasicTextEncryptor();
        textEncryptor.setPassword(salt);
        String pwd = textEncryptor.decrypt(encryptString);
        System.out.println("解密后:" + pwd);
        return pwd;
    }
}

  • 14
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Spring Boot是一个开源的Java框架,可帮助开发者更快速地构建应用程序。Jasypt3是Spring Boot中一种常用的加密库,可用于加密敏感数据,如数据库密码。下面简要介绍如何使用Spring BootJasypt3来加密数据库密码: 1. 添加依赖:在pom.xml中添加Jasypt3的依赖,如下所示: ```xml <dependency> <groupId>com.github.ulisesbocchio</groupId> <artifactId>jasypt-spring-boot-starter</artifactId> <version>3.0.3</version> </dependency> ``` 2. 配置加密算法和密钥: 在Spring Boot的配置文件(application.properties或application.yml)中添加以下配置: ```properties jasypt.encryptor.algorithm=算法 jasypt.encryptor.password=密钥 ``` 3. 加密数据库密码: 在配置文件使用Jasypt3提供的加密语法将数据库密码进行加密。例如,假设我们要加密密码是"password",可以使用以下语法: ```properties encryptor.encrypt(密码) ``` 4. 使用加密密码: 在项目中的数据源配置文件(如application.properties)中,使用加密后的密码。例如: ```properties spring.datasource.username=用户名 spring.datasource.password=ENC(加密密码) ``` 5. 运行应用程序: 启动Spring Boot应用程序,它将自动使用配置的密钥解密密码,然后使用解密后的密码连接数据库。 通过以上步骤,我们可以使用Spring BootJasypt3来实现数据库密码加密。这样可以保护敏感数据的安全性,同时提供了一种方便的方法来管理加密密钥和加密算法。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

逆天-逍遥哥哥

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值