使用 Spring Boot 进行加密和解密:SecretKeySpec 和 Cipher

在现代软件开发中,数据加密和解密是保护敏感信息的重要手段。本文将介绍如何在 Spring Boot 项目中使用 Java 的 SecretKeySpecCipher 类来实现对称加密和解密。

为什么选择对称加密?

对称加密算法使用相同的密钥进行加密和解密。其主要优点包括速度快和实现简单。常见的对称加密算法有 AES、DES 等。本文将以 AES 为例,展示如何在 Spring Boot 项目中进行数据加密和解密。

对称加密
概念

对称加密(Symmetric Encryption)是一种使用单一密钥(即同一密钥)进行加密和解密的加密方法。加密和解密过程使用相同的密钥,因此加密方和解密方都必须拥有该密钥。

特点
  1. 速度快:对称加密算法通常比非对称加密算法快,因为它们的计算复杂度较低。
  2. 容易实现:对称加密算法的实现相对简单,且计算效率高。
  3. 密钥管理复杂:由于加密和解密使用相同的密钥,密钥的分发和管理非常重要且复杂。密钥泄露将导致加密数据的安全性受到威胁。
常见算法
  • AES(Advanced Encryption Standard)
  • DES(Data Encryption Standard)
  • 3DES(Triple DES)
  • RC4(Rivest Cipher 4)
  • Blowfish
应用场景
  • 数据库加密
  • 文件加密
  • 网络通信中的数据加密(如HTTPS中的对称加密部分)
非对称加密
概念

非对称加密(Asymmetric Encryption)是一种使用一对密钥(公钥和私钥)进行加密和解密的加密方法。公钥用于加密,私钥用于解密。公钥可以公开发布,而私钥必须保密。

特点
  1. 安全性高:由于使用公钥和私钥对,私钥不需要在通信双方之间传递,因此安全性更高。
  2. 速度慢:非对称加密算法通常比对称加密算法慢,因为它们的计算复杂度较高。
  3. 密钥管理简单:由于公钥可以公开,只有私钥需要保密,所以密钥管理相对简单。
常见算法
  • RSA(Rivest-Shamir-Adleman)
  • DSA(Digital Signature Algorithm)
  • ECC(Elliptic Curve Cryptography)
应用场景
  • 数字签名:验证数据的来源和完整性。
  • 密钥交换:在安全通道中交换对称加密的密钥,如TLS/SSL协议。
  • 电子邮件加密:如PGP(Pretty Good Privacy)。
对比总结
  • 密钥使用
    • 对称加密使用相同的密钥进行加密和解密。
    • 非对称加密使用一对密钥(公钥和私钥)进行加密和解密。
  • 速度
    • 对称加密速度快,适合大数据量的加密。
    • 非对称加密速度慢,通常用于少量数据的加密或密钥交换。
  • 安全性
    • 对称加密密钥管理复杂,密钥泄露风险较大。
    • 非对称加密安全性高,适合公开密钥的场景。
实际应用结合

在实际应用中,常常将对称加密和非对称加密结合使用。例如,在HTTPS协议中,首先使用非对称加密进行密钥交换,然后使用对称加密进行数据传输。这样既保证了密钥的安全性,又提高了数据传输的效率。

项目设置

首先,确保你的 Spring Boot 项目已经创建并运行。你可以使用 Spring Initializr 或者你的 IDE 快速创建一个新的 Spring Boot 项目。

添加依赖

pom.xml 文件中添加以下依赖:

<dependencies><dependency><groupId>org.springframework.bootgroupId><artifactId>spring-boot-starterartifactId>dependency><dependency><groupId>org.springframework.bootgroupId><artifactId>spring-boot-starter-webartifactId>dependency>
dependencies>
创建加密和解密工具类

接下来,我们创建一个工具类 CryptoUtil,用于实现加密和解密功能。

package com.example.demo.util;import javax.crypto.Cipher;
import javax.crypto.spec.SecretKeySpec;
import java.util.Base64;public class CryptoUtil {private static final String ALGORITHM = "AES";private static final String TRANSFORMATION = "AES";// 16-byte secret keyprivate static final String SECRET_KEY = "mySuperSecretKey";public static String encrypt(String input) throws Exception {SecretKeySpec keySpec = new SecretKeySpec(SECRET_KEY.getBytes(), ALGORITHM);Cipher cipher = Cipher.getInstance(TRANSFORMATION);cipher.init(Cipher.ENCRYPT_MODE, keySpec);byte[] encryptedBytes = cipher.doFinal(input.getBytes());return Base64.getEncoder().encodeToString(encryptedBytes);}public static String decrypt(String input) throws Exception {SecretKeySpec keySpec = new SecretKeySpec(SECRET_KEY.getBytes(), ALGORITHM);Cipher cipher = Cipher.getInstance(TRANSFORMATION);cipher.init(Cipher.DECRYPT_MODE, keySpec);byte[] decodedBytes = Base64.getDecoder().decode(input);byte[] decryptedBytes = cipher.doFinal(decodedBytes);return new String(decryptedBytes);}
}
创建 REST 控制器

接下来,我们创建一个 REST 控制器来测试加密和解密功能。

package com.example.demo.controller;import com.example.demo.util.CryptoUtil;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;@RestController
public class CryptoController {@GetMapping("/encrypt")public String encrypt(@RequestParam String plaintext) {try {return CryptoUtil.encrypt(plaintext);} catch (Exception e) {e.printStackTrace();return "Error encrypting data";}}@GetMapping("/decrypt")public String decrypt(@RequestParam String ciphertext) {try {return CryptoUtil.decrypt(ciphertext);} catch (Exception e) {e.printStackTrace();return "Error decrypting data";}}
}
测试加密和解密

启动 Spring Boot 应用,并使用浏览器或者 Postman 访问以下 URL:

  1. 加密:
http://localhost:8080/encrypt?plaintext=HelloWorld
  1. 你将会得到一个加密后的字符串,例如:
YWJjZGVmZ2hpamtsbW5vcHFy
  1. 解密:
http://localhost:8080/decrypt?ciphertext=YWJjZGVmZ2hpamtsbW5vcHFy
  1. 你将会得到解密后的原文:
HelloWorld
总结

通过本文,你学会了如何在 Spring Boot 项目中使用 SecretKeySpecCipher 实现对称加密和解密。我们使用 AES 算法对字符串进行加密和解密,并通过 REST 控制器来测试这些功能。希望这篇文章对你有所帮助,并能为你的项目提供安全性保障。如果你有任何问题或建议,欢迎随时交流。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/60124.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

解决 Vue3、Vite 和 TypeScript 开发环境下跨域的问题,实现前后端数据传递

引言 本文介绍如何在开发环境下解决 Vite 前端&#xff08;端口 3000&#xff09;和后端&#xff08;端口 80&#xff09;之间的跨域问题&#xff1a; 在开发环境中&#xff0c;前端使用的 Vite 端口与后端端口不一致&#xff0c;会产生跨域错误提示&#xff1a; Access to X…

Java项目实战II基于微信小程序的订餐系统(开发文档+数据库+源码)

目录 一、前言 二、技术介绍 三、系统实现 四、文档参考 五、核心代码 六、源码获取 全栈码农以及毕业设计实战开发&#xff0c;CSDN平台Java领域新星创作者&#xff0c;专注于大学生项目实战开发、讲解和毕业答疑辅导 一、前言 随着移动互联网技术的飞速发展&#xff0…

闯关leetcode——202. Happy Number

大纲 题目地址内容 解题代码地址 题目 地址 https://leetcode.com/problems/happy-number/description/ 内容 Write an algorithm to determine if a number n is happy. A happy number is a number defined by the following process: Starting with any positive inte…

昇思大模型平台打卡体验活动:项目4基于MindSpore实现Roberta模型Prompt Tuning

基于MindNLP的Roberta模型Prompt Tuning 本文档介绍了如何基于MindNLP进行Roberta模型的Prompt Tuning&#xff0c;主要用于GLUE基准数据集的微调。本文提供了完整的代码示例以及详细的步骤说明&#xff0c;便于理解和复现实验。 环境配置 在运行此代码前&#xff0c;请确保…

中国药品注册审批数据库- 药品注册信息查询与审评进度查询方法

药品的注册、审评审批进度信息是医药研发相关人员每天都会关注的信息&#xff0c;为了保证药品注册申请受理及审评审批进度信息的公开透明&#xff0c;CDE药审中心提供药品不同注册分类序列及药品注册申请受理的审评审批进度信息查询服务。但因CDE官网的改版导致很大一部分人不…

FMC 扩展子卡6 路 422,8 组 LVDS,8 路 GPIO

FMC 扩展子卡6 路 422,8 组 LVDS,8 路 GPIO 卡是一款支持多路 LVCMOS 和 LVDS 信号互转的 FMC 扩展子板。它能支持 6 路 422 信号的输入 / 输出 ,8 组 LVDS 信号的输入 / 输出和 8 路 GPIO 信号的输入 / 输出。本产品基于一些逻辑转换芯片而设计&#xff0c;能实现差分信号转单…

C++builder中的人工智能(21):Barabási–Albert model(BA)模型

在此之前&#xff0c;大多数网络被想当然的认为是随机的&#xff0c;因此连接度分布可以近似用泊松分布来表示&#xff0c;而巴拉巴西与其学生阿尔伯特、郑浩雄通过对万维网度分布测量的结果却显示万维网度分布服从幂律分布&#xff0c;存在枢纽节点&#xff08;拥有大量链接的…

MyBatis3-获取参数值的方式、查询功能及特殊SQL执行

目录 准备工作 获取参数值的方式&#xff08;重点&#xff09; 查询功能 查询一个实体类对象 查询一个list集合 查询单个数据 查询一条数据为map集合 查询多条数据为map集合 特殊SQL执行 模糊查询 批量删除 动态设置表名 添加功能获取自增的主键 准备工作 模块My…

链表(Linkedlist)

序言 我们都了解链表是一种数据的存储结构&#xff0c;在Java使用中逻辑与c&#xff0c;c语言数据结构别无二致&#xff0c;但主要由于Java中不存在指针的说法&#xff0c;从而导致在实现过程中的代码不同&#xff0c;所以在学习的过程中我们无需过于担心&#xff0c;逻辑都是…

【分布式事务】二、NET8分布式事务实践: DotNetCore.CAP 框架 、 消息队列(RabbitMQ)、 多类型数据库(MySql、MongoDB)

介绍 DotNetCore.CAP简称CAP, [CAP]是一个用来解决微服务或者分布式系统中分布式事务问题的一个开源项目解决方案, 同样可以用来作为 EventBus 使用,CAP 拥有自己的特色,它不要求使用者发送消息或者处理消息的时候实现或者继承任何接口,拥有非常高的灵活性。我们一直坚信…

利用pythonstudio写的PDF、图片批量水印生成器,可同时为不同读者生成多组水印

现在很多场合需要将PDF或图片加水印&#xff0c;本程序利用pythonstudio编写。 第一步 界面 其中&#xff1a; LstMask:列表框 PopupMenu:PmnMark LstFiles:列表框 PopupMenu:PmnFiles OdFiles:文件选择器 Filter:PDF文件(.PDF)|.PDF|图像文件(.JPG)|.JPG|图像文件(.png…

面试:TCP、UDP如何解决丢包问题

文章目录 一、TCP丢包原因、解决办法1.1 TCP为什么会丢包1.2 TCP传输协议如何解决丢包问题1.3 其他丢包情况&#xff08;拓展&#xff09;1.4 补充1.4.1 TCP端口号1.4.2 多个TCP请求的逻辑1.4.3 处理大量TCP连接请求的方法1.4.4 总结 二、UDP丢包2.1 UDP协议2.1.1 UDP简介2.1.2…

Python的函数(补充浅拷贝和深拷贝)

一、定义 函数的定义&#xff1a;实现【特定功能】的代码块。 形参&#xff1a;函数定义时的参数&#xff0c;没有实际意义 实参&#xff1a;函数调用/使用时的参数&#xff0c;有实际意义 函数的作用&#xff1a; 简化代码提高代码重用性便于维护和修改提高代码的可扩展性…

Spring Boot框架的知识分类技术解析

2 开发技术 2.1 VUE框架 Vue.js&#xff08;读音 /vjuː/, 类似于 view&#xff09; 是一套构建用户界面的渐进式框架。 Vue 只关注视图层&#xff0c; 采用自底向上增量开发的设计。 Vue 的目标是通过尽可能简单的 API 实现响应的数据绑定和组合的视图组件。 2.2 Mysql数据库 …

Hive详解

1 Hive基本概念 Hive是一个构建在Hadoop上的数据仓库框架。最初&#xff0c;Hive是由Facebook开发&#xff0c;后来移交由Apache软件基金会开发&#xff0c;并作为一个Apache开源项目。 Hive是基于Hadoop的一个数据仓库工具&#xff0c;可以将结构化的数据文件映射为一张数据…

llamaIndex和langchain对比及优劣对比

一. LangChain vs LlamaIndex: 基本描述 LlamaIndex在搜索和检索任务方面表现出色。它是一个强大的数据索引和查询工具&#xff0c;非常适合需要高级搜索的项目。LlamaIndex能够处理大型数据集&#xff0c;从而实现快速准确的信息检索。 LangChain是一个模块化和灵活的工具集框…

《重学Java设计模式》之 工厂方法模式

《重学Java设计模式》之 建造者模式 《重学Java设计模式》之 原型模式 《重学Java设计模式》之 单例模式 模拟发奖多种商品 工程结构 奖品发放接口 package com.yys.mes.design.factory.store;public interface ICommodity {/*** Author Sherry* Date 14:20 2024/11/6**/voi…

【C++笔记】string类的模拟实现

前言 各位读者朋友们大家好&#xff01;上期我们讲解了string类的基础用法&#xff0c;这期我们来模拟实现一下string类。 目录 前言一. string类的构造函数1. 1 无参构造2.2 带参构造1.3 无参和带参构造结合1.4 拷贝构造1.5 c_str 二. string类的析构函数三. 字符串的遍历3.…

java中ArrayList的使用存储对象的易错点

ArrayList存储对象的易错点 上面这种写法是有逻辑问题的&#xff0c;因为只创建了一个Student对象&#xff0c;因此最后打印出来的结果是三个最后赋值的结果。 下面我们来形象看下存储关系 集合中存储的始终是第一个对象的地址&#xff0c;而每次输入新的名字和年龄&#xf…

栈和队列(Java)

一.栈&#xff08;Stack&#xff09; 1.定义 栈是限定仅在表尾进行插入或删除操作的线性表 一般的表尾称为栈顶 表头称为栈底 栈具有“后进先出”的特点 2.对栈的模拟 栈主要具有以下功能&#xff1a; push(Object item)&#xff1a;将元素item压入栈顶。 pop()&am…