0

0

在Java中如何完成文本加密解密示例_Java字符串处理解析

P粉602998670

P粉602998670

发布时间:2026-01-28 11:23:03

|

998人浏览过

|

来源于php中文网

原创

AES加密报BadPaddingException主因是密钥长度、填充方式或编码不一致;需确保密钥为16/24/32字节、加解密参数完全相同、IV固定或传输、统一UTF-8编码,并用java.util.Base64安全转换密文。

在java中如何完成文本加密解密示例_java字符串处理解析

Java中用AES加密字符串为什么总报BadPaddingException

多数情况不是算法写错了,而是密钥长度、填充方式或字符编码不一致导致的。AES要求密钥必须是128/192/256位(即16/24/32字节),用SecretKeySpec构造时若传入的字符串没转成对应字节数组,就容易出错。

  • 确保密钥是32字节(如用MessageDigest对原始字符串SHA-256哈希后取前32字节)
  • 加解密必须用完全相同的Cipher实例化参数,例如"AES/CBC/PKCS5Padding",不能一边用PKCS5Padding,另一边用NoPadding
  • 初始化向量IV必须固定或随密文一起传输;若用SecureRandom每次生成新IV,解密时没保存它就必然失败
  • 字符串编解码统一用StandardCharsets.UTF_8,避免new String(bytes)默认平台编码引发乱码

如何安全地把加密结果转成可存储的字符串

二进制密文不能直接当字符串用,常见做法是Base64编码。但别用sun.misc.BASE64Encoder(已废弃且非标准),改用java.util.Base64

  • 加密后调用Base64.getEncoder().encodeToString(cipher.doFinal(plainBytes))
  • 解密前先用Base64.getDecoder().decode(encodedString)还原为字节数组
  • 如果密文要存数据库或传HTTP,Base64是稳妥选择;若需URL安全,可用Base64.getUrlEncoder()

为什么用DES加密在Java 21里直接抛NoSuchAlgorithmException

JDK 17+默认禁用DES(含DESede),因为密钥太短、易被暴力破解。OpenJDK和Oracle JDK都已将其列为“insecure”,运行时策略文件java.securityjdk.crypto.disabledAlgorithms会拦截。

Interior AI
Interior AI

AI室内设计,上传室内照片自动帮你生成多种风格的室内设计图

下载
  • 别再用KeyGenerator.getInstance("DES"),改用AES
  • 如果必须兼容旧系统,可临时修改JAVA_HOME/conf/security/java.security,删掉DES相关条目(不推荐)
  • 注意:即使启用,DES的56位有效密钥强度在现代计算下已无实际安全意义

加解密工具类要不要把Cipher实例缓存复用

不要缓存Cipher对象。它不是线程安全的,且内部状态(如opmodeiv)会在doFinal()后被清空或改变。

立即学习Java免费学习笔记(深入)”;

  • 每次加解密都应新建Cipher:用Cipher.getInstance("AES/CBC/PKCS5Padding")
  • 可以缓存SecretKeyIvParameterSpec(只要它们本身不变)
  • 高频场景下,反复getInstance开销极小,远低于因共享Cipher导致的并发异常或解密失败
AES的密钥派生、IV管理、认证加密(如AES-GCM)这些环节一旦漏掉,表面能跑通,实际可能被篡改或重放。真要上线,别只套个Cipher.doFinal就完事。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

443

2023.08.02

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

443

2023.08.02

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

298

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

212

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1500

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

623

2023.11.24

java读取文件转成字符串的方法
java读取文件转成字符串的方法

Java8引入了新的文件I/O API,使用java.nio.file.Files类读取文件内容更加方便。对于较旧版本的Java,可以使用java.io.FileReader和java.io.BufferedReader来读取文件。在这些方法中,你需要将文件路径替换为你的实际文件路径,并且可能需要处理可能的IOException异常。想了解更多java的相关内容,可以阅读本专题下面的文章。

613

2024.03.22

php中定义字符串的方式
php中定义字符串的方式

php中定义字符串的方式:单引号;双引号;heredoc语法等等。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

588

2024.04.29

俄罗斯Yandex引擎入口
俄罗斯Yandex引擎入口

2026年俄罗斯Yandex搜索引擎最新入口汇总,涵盖免登录、多语言支持、无广告视频播放及本地化服务等核心功能。阅读专题下面的文章了解更多详细内容。

84

2026.01.28

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
SQL 教程
SQL 教程

共61课时 | 3.6万人学习

Java 教程
Java 教程

共578课时 | 52.4万人学习

oracle知识库
oracle知识库

共0课时 | 0人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号