Springboot yml配置参数数据加密 (数据加密篇 一)

简介: Springboot yml配置参数数据加密 (数据加密篇 一)

前言



最近项目组开始关注一些敏感数据的明文相关的事宜 , 其实这些东西也是都有非常成熟的解决方案。 既然最近着手去解决这些事情,那么也顺便给还未了解的大伙普及一下。


这个系列就暂短的分成三篇 :


第一篇    yml配置文件里敏感数据的加密


第二篇    传入数据敏感数据的加密存储


第三篇     使用mysql加解密函数轻松实现


Springboot 使用mysql加密解密函数 (数据加密篇 三)_默默不代表沉默-CSDN博客


本篇是第一篇


正文



先看我们的实践项目例子 :image.png


我们目标是想对这些我们认为是敏感的数据加密,不能这么明白的展现出来 。


1. pom文件引入依赖:

 

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


2.yml引入加密钥匙配置 :


1. 
2. #jasypt加密的密匙
3. jasypt:
4.   encryptor:
5.     password: JCCCCgd6Tsjckd87xGy6H1JGb47G2H72


这里注意,如果直接把加密password这样摆在yml里面,其实也是敏感的, 一会文章后面会介绍把这个当作启动参数传入。


3.开始事宜jasypt 加密 :


我们把需要加密的敏感数据拿出来,提前加密:


    @Autowired
    StringEncryptor encryptor;
    @Test
    void contextLoads() {
        String dbUrl = encryptor.encrypt("jdbc:mysql://localhost:3306/mytest?useSSL=false&useUnicode=true&characterEncoding=UTF-8&serverTimezone=GMT%2B8&zeroDateTimeBehavior=convertToNull");
        System.out.println(dbUrl);
        String username = encryptor.encrypt("root");
        System.out.println(username);
        String password = encryptor.encrypt("root");
        System.out.println(password);
    }


image.png


可以拿到对应加密出来的数据 。


4.使用jasypt 的解析规则,把加密完后的数据替换配置到 yml文件里:

 

规则  ENC(加密数据)


image.png


5. 运行项目,调用查询接口,看看是否能正常获取数据库数据,校验相关敏感数据是能正常解密解析的:


image.png


ok,到这里我们已经完成了本篇的实践内容 。


我们最后来针对这个  jasypt的加密解密使用钥匙做点事情,


我们要把这个参数变成 不写死不暴露 的:


image.png


方案提供思路: 当作启动参数传入


实践:


我们把yml的钥匙去掉, 保留原先加密完的数据配置 :


spring:
  datasource:
    druid:
     url: ENC(OGNie1iT/W6LBSdXvmIv/tyQA69HbI1OUSh3MM/UeTv2dufbuJBu0aEf7EN86DOPiXOZyHtYTVwu+3AHtmPPZYxXbaw9xU04x8POZsWjx6BmQBmdNRyBVcO7IixG9F+WK6+jlRhXEsgqTk+MOpDuPBBmf8Zw+LoWeKPICfqn2SOJAOJ2gSrE7wDSR4YRejgDWDPcMIvo4yfKG8pJZZ6OeQ==)
     username: ENC(cuaMHDblkuVeHSFyV+OKmQ==)
     password: ENC(BEQNsEv0gIkvRWwg2P9ktg==)
server:
  port: 8766
mybatis:
  config-location: classpath:mybatis/mybatis-config.xml
  mapper-locations: classpath:mybatis/mapper/*.xml


然后当作 启动参数传入


-Djasypt.encryptor.password=JCCCCgd6Tsjckd87xGy6H1JGb47G2H72


如果是使用jar运行就对应命令里面加入  类似:


java -jar -Djasypt.encryptor.password=JCCCCgd6Tsjckd87xGy6H1JGb47G2H72 XXX-xxxx.jar


模拟测试一下这种方式:


image.png


测试结果:


image.png

相关文章
|
26天前
|
Java Spring
SpringBoot接收参数的方式
本文介绍了Java Spring Boot中处理GET请求的多种方式。可以使用方法参数直接接收,或者通过`@RequestParam`注解指定必传参数。此外,可以用实体类接收多个相关参数,但不能同时使用`@RequestParam`。还可以通过`HttpServletRequest`对象获取参数,或利用`@PathVariable`接收路径变量。对于数组和集合参数,需注意使用`@RequestParam`注解。
134 1
|
11天前
|
算法 Java 数据安全/隐私保护
使用 Spring Boot 进行加密和解密:SecretKeySpec 和 Cipher
【6月更文挑战第7天】在现代软件开发中,数据加密和解密是保护敏感信息的重要手段。本文将介绍如何在 Spring Boot 项目中使用 Java 的 SecretKeySpec 和 Cipher 类来实现对称加密和解密。
13 1
|
25天前
|
Java 应用服务中间件 Maven
SpringBoot概述&SpringBoot基础配置&yml的使用&多环境启动
SpringBoot概述&SpringBoot基础配置&yml的使用&多环境启动
35 2
|
1月前
|
Java
Springboot 使用自定义注解结合AOP方式校验接口参数
Springboot 使用自定义注解结合AOP方式校验接口参数
Springboot 使用自定义注解结合AOP方式校验接口参数
|
1月前
|
前端开发 Java
SpringBoot之自定义注解参数校验
SpringBoot之自定义注解参数校验
27 2
|
1月前
|
Java 微服务 Spring
Spring Boot中获取配置参数的几种方法
Spring Boot中获取配置参数的几种方法
29 2
|
1月前
|
存储 Java 数据库
SpringBoot使用jasypt实现数据库配置加密
这样,你就成功地使用Jasypt实现了Spring Boot中的数据库配置加密,确保敏感信息在配置文件中以加密形式存储,并在应用启动时自动解密。
79 2
|
1月前
|
开发框架 Java 开发者
Spring Boot接收参数的多种方式
【4月更文挑战第20天】
68 0
|
1月前
|
JSON 前端开发 Java
SpringBoot之JSON参数,路径参数的详细解析
SpringBoot之JSON参数,路径参数的详细解析
25 0
|
1天前
|
SQL 监控 安全
网络安全的守护者:漏洞、加密与意识
【6月更文挑战第16天】在数字时代的浪潮中,网络安全和信息安全成为了保护个人隐私和企业资产的重要屏障。本文将深入探讨网络安全的核心要素,包括常见的网络漏洞、先进的加密技术以及不可或缺的安全意识。通过分析这些关键领域,我们旨在为读者提供一份全面的网络安全知识指南,帮助他们在日益复杂的网络环境中保持警觉,并采取有效措施以防范潜在的网络威胁。