2025年springboot 之 使用jasypt加密解密插件[通俗易懂]

springboot 之 使用jasypt加密解密插件[通俗易懂]简单使用 jasypt 是一个 java 实现的安全框架 1 该工具支持注解方式开启 jasypt 功能 以及注解方式引入一个或多个需要处理的配置文件 2 该工具同时支持 properties 与 yml 文件的解析处理 3 该工具支持自定义加解密类型和复写加解密方法 引入插件 com github ulisesbocchi jasypt spring boot starter 2 1 0 pre

简单使用

jasypt是一个java实现的安全框架

1、该工具支持注解方式开启jasypt功能,以及注解方式引入一个或多个需要处理的配置文件。

2、该工具同时支持properties与yml文件的解析处理。

3、该工具支持自定义加解密类型和复写加解密方法。

引入插件


com.github.ulisesbocchio
jasypt-spring-boot-starter
2.1.0

/pre>

h4>默认情况下jasypt采用的算法是PBEWithMD5AndDES,该算法对同一串明文每次加密的密文都不一样,比较适合做数据加解密。但是该算法必须配置密码

/h4>

h3>在配置文件中设置加解密密码

/h3>

pre class='language-javascript'>

#指定加解密时使用的密码
jasypt.encryptor.password=rB8Bf1uvMvyALBoKAFfcKZuWT20208

/pre>

h3>配置文件中设置需要加密解密的字串

/h3>

pre class='language-javascript'>

#ENC表示需要解密,这里将这个配置变量注入到一个变量内,那么那个变量内容就是“123456”
# @Value("${spring.datasource.password}")
# private String password;
spring.datasource.password=ENC(X+wQOPz4HKvfnSjkBi4r1w==)

/pre>

h3>当然我们也可以直接使用jar包生成

/h3>

pre class='language-javascript'>

cd到jasypt-1.9.2.jar的当前目录,input输入要加密的字符串,password为解密时的钥匙
命令行加密:
java -cp jasypt-1.9.2.jar org.jasypt.intf.cli.JasyptPBEStringEncryptionCLI input="root" password=security algorithm=PBEWithMD5AndDES
命令行解密:
java -cp jasypt-1.9.2.jar org.jasypt.intf.cli.JasyptPBEStringDecryptionCLI input="i00VogiiZ1FpZR9McY7XNw==" password=security algorithm=PBEWithMD5AndDES

/pre>

h3>

/h3>

h3>自定义加密方法

/h3>

p>如果需要使用自定义的加减密方法,我们只需要实现StringEncryptor接口即可,具体如下:

/p>

p>1.实现接口

/p>

pre class='language-javascript'>

import org.jasypt.encryption.StringEncryptor;

public class DESEncrypt implements StringEncryptor {

//加密
@Override
public String encrypt(String message) {
try {

return 自己定义的方法的返回值;//如果方法中包含加密密匙那么就完全没必要在配置文件中写
} catch (Exception e) {
e.printStackTrace();
return message;
}
}

//解密
@Override
public String decrypt(String encryptedMessage) {
try {

return 自己定义的方法的返回值;
} catch (Exception e) {
e.printStackTrace();
return encryptedMessage;
}
}

}

/pre>

p>2.创建bean

/p>

p>使用java config方式实例化该对象替换默认的StringEncryptor实例

/p>

pre class='language-javascript'>

import org.jasypt.encryption.StringEncryptor;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

@Configuration
public class EncryptionConfig {

@Bean("jasyptStringEncryptor")
public StringEncryptor stringEncryptor() {
DESEncrypt desEncrypt = new DESEncrypt();//调用我们自己实现的类即可
return desEncrypt;
}
}

/pre>

p>参考网址:

/p>

p>https://www.cnblogs.com/qingfengsuixin/p/10756604.html

/p>

p>https://yq.aliyun.com/articles/182720?utm_content=m_29522

/p>

p>https://github.com/ulisesbocchio/jasypt-spring-boot?spm=a2c4e.10696291.0.0.41fe19a4Ldsp1T

/p>

编程小号
上一篇 2025-01-24 16:46
下一篇 2025-02-11 17:46

相关推荐

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:https://bianchenghao.cn/hz/140865.html