当前位置: 首页 > news >正文

【Android】AES解密抛出异常Cipher functions:OPENSSL_internal:WRONG_FINAL_BLOCK_LENGTH

Java使用AES加密的时候没得问题,但是在解密的时候就出错了,一起来找找原因吧。

首先,Java运行的代码如下,使用AES加解密

Cipher cipher = Cipher.getInstance("AES/CBC/NOPadding");
//...

主要问题

可调试运行控制台抛出异常:

Cipher functions:OPENSSL_internal:WRONG_FINAL_BLOCK_LENGTH

❓看不懂英文?借助翻译工具吧

仔细看看,加密的结果字符串长度,没看出问题吧

SkBJS7W4VaQDCaHJdY97eeaZ6HdTJEyf2n9k/ovIECc=

💡再想办法,绕绕头,掉了几根头发后…

借助阅读工具看到,会发现多了一个容易忽略的换行符

SkBJS7W4VaQDCaHJdY97eeaZ6HdTJEyf2n9k/ovIECc=\n

没想到真的是跟长度有关,复制的时候没有把换行符一起带上

其它问题

报错1

Wrong IV length: must be 16 bytes long
表示用于VI加解密的密钥字符串长度必须是16位

尝试填充字符串

报错2

IV not used in ECB mode
表示用于VI加解密不要使用ECB模式

尝试改成

Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5PADDING");

再不看懂英文就Out了

请添加图片描述

http://www.lryc.cn/news/145368.html

相关文章:

  • 菜鸟教程《Python 3 教程》笔记(2):数据类型转换
  • JVM运行时参数查看
  • 每日一题:leetcode 1267 统计参与通信的服务器
  • Unity打包Windows程序,概率性出现无法全屏或分辨率不匹配
  • 消息中间件 介绍
  • JAVA-字符串长度
  • [oneAPI] 基于BERT预训练模型的SWAG问答任务
  • 如何为winform控件注册事件
  • 【LeetCode-面试经典150题-day15】
  • git查看和修改项目远程仓库地址
  • JavaWeb 速通JSON
  • 20 MySQL(下)
  • 测试圈的网红工具:Jmeter到底难在哪里?!
  • 深度学习10:Attention 机制
  • 简单着色器编写(中下)
  • matlab使用教程(24)—常微分方程(ODE)求解器
  • 企业级数据共享规模化模式
  • Web服务器-Tomcat详细原理与实现
  • ARM处理器核心概述
  • 万户协同办公平台 ezoffice存在未授权访问漏洞 附POC
  • 使用ctcloss训练矩阵生成目标字符串
  • 驱动 - 20230829
  • 数组(个人学习笔记黑马学习)
  • layui表格事件分析实例
  • Android NDK JNI与Java的相互调用
  • 装备制造企业如何执行精益管理?
  • PHP8中自定义函数-PHP8知识详解
  • 虚拟化技术:云计算发展的核心驱动力
  • 光伏+旅游景区
  • 手搓文本向量数据库(自然语言搜索生成模型)