项目场景:对登录用户名、密码前端加密,后端解密失败


问题描述

在做login登录页面的用户名和密码加密时,前端加密后端解密,但是抛出报错:Input length must be multiple of 16 when decrypting with padded cipher,仔细检查过偏移向量,没有问题,但还是不行,于是在后端测试,先加密,后解密,测试发现一切正常,那问题就应该出现在传参上面,应该是字符转义的问题;

这是前端传入的加密后的用户名和密码

{"username": "8RKHWcE11foCm2%2BaEuFG6w%3D%3D","password": "TQafftXrh8aXYNFJcPgw1w%3D%3D",
}

原因分析:

前端enCode在后端解析失败,最后的%3D无法解析,导致偏移向量对应不上,报错


解决方案:

----------------------------------------解决方案---------------------------------------String un="8RKHWcE11foCm2%2BaEuFG6w%3D%3D";String pd="TQafftXrh8aXYNFJcPgw1w%3D%3D";//先转编码!!!String ufUserName = URLDecoder.decode(un, "UTF-8");String ufPassWord = URLDecoder.decode(pd, "UTF-8");//此时里面的%3D 解析成了=//8RKHWcE11foCm2%2BaEuFG6w==//TQafftXrh8aXYNFJcPgw1w==//然后再去解密String userName = AESUtil.decrypt(ufUserName, MD5.create().digestHex16("dq"));String passWord = AESUtil.decrypt(ufPassWord, MD5.create().digestHex16("dq"));----------------------------------下面是封装的加解密方法,可以忽略----------------------------------/*** @desc: AES加密工具* @date: 2021/11/15 15:00* @author: 杨永卓*/
public class AESUtil {static Logger logger = LoggerFactory.getLogger(AESUtil.class);// 密钥public static String key = MD5.create().digestHex16("tpp-cloud");private static String charset = "utf-8";// 偏移量private static int offset = 16;// 加密器类型:加密算法为AES,加密模式为CBC,补码方式为PKCS5Paddingprivate static String transformation = "AES/CBC/PKCS5Padding";// 算法类型:用于指定生成AES的密钥private static String algorithm = "AES";/*** 加密** @param content* @return*/public static String encrypt(String content) {return encrypt(content, key);}/*** 解密** @param content* @return*/public static String decrypt(String content) {return decrypt(content, key);}/*** 加密** @param content*            需要加密的内容* @param key*            加密密码* @return*/public static String encrypt(String content, String key) {try {// 构造密钥SecretKeySpec skey = new SecretKeySpec(key.getBytes(), algorithm);// 创建初始向量iv用于指定密钥偏移量(可自行指定但必须为128位),因为AES是分组加密,下一组的iv就用上一组加密的密文来充当IvParameterSpec iv = new IvParameterSpec(key.getBytes(), 0, offset);// 创建AES加密器Cipher cipher = Cipher.getInstance(transformation);byte[] byteContent = content.getBytes(charset);// 使用加密器的加密模式cipher.init(Cipher.ENCRYPT_MODE, skey, iv);// 加密byte[] result = cipher.doFinal(byteContent);// 使用BASE64对加密后的二进制数组进行编码return new Base64().encodeAsString(result);} catch (Exception e) {logger.info("", e);}return null;}/*** AES(256)解密** @param content*            待解密内容* @param key*            解密密钥* @return 解密之后* @throws Exception*/public static String decrypt(String content, String key) {try {SecretKeySpec skey = new SecretKeySpec(key.getBytes(), algorithm);IvParameterSpec iv = new IvParameterSpec(key.getBytes(), 0, offset);Cipher cipher = Cipher.getInstance(transformation);// 解密时使用加密器的解密模式cipher.init(Cipher.DECRYPT_MODE, skey, iv);// 初始化byte[] result = cipher.doFinal(new Base64().decode(content));return new String(result); // 解密} catch (Exception e) {logger.info("", e);}return null;}// public static void main(String[] args) {// String s = "2021!";// String encryptResultStr = encrypt(s);// // 加密// System.out.println("加密前:" + s);// System.out.println("加密后:" + encryptResultStr);// // 解密// System.out.println("解密后:" + decrypt(encryptResultStr));// System.out.println("解密后:" + decrypt("2o3nQ7k4k/13R2CNab0VkA==",key));//// }

具体解决就是:在解密前再转一次编码,基本就能解决这一报错问题。

AES解密报错,Input length must be multiple of 16 when decrypting with padded cipher相关推荐

  1. JAVA实现AES 解密报错Input length must be multiple of 16 when decrypting with padded cipher

    加密代码 /*** 加密* * @param content 需要加密的内容* @param password 加密密码* @return*/public static byte[] encrypt( ...

  2. AES加密/解密报错,Input length must be multiple of 16 when decrypting with padded cipher

    背景:需要存储一个类似密钥的字符串,密文存储,并要求能逆向解密出来. 问题描述:使用AES对该字符串进行加密后生成byte数组,使用new String()方法转为字符串后存储到数据库. 从数据库中取 ...

  3. AES解密报错:Given final block not properly padded. Such issues can arise if a bad key is used during dec

    问题:系统登录账号密码密文传输,用AES加密之后:登录的时候抛出: javax.crypto.BadPaddingException: Given final block not properly p ...

  4. AES 解密报错:Given final block not properly padded. Such issues can arise if a bad key is used dur

    问题:系统登录账号密码密文传输,用AES加密之后:登录的时候抛出:Given final block not properly padded. Such issues can arise if a b ...

  5. Linux环境AES解密报错:Given final block not properly padded. Such issues can arise if a bad key is used dur

    将代码替换: String charset = "utf-8"; KeyGenerator kg = KeyGenerator.getInstance("AES" ...

  6. 微信小程序手机号解密报错:pad block corrupted 解决方法

    微信小程序手机号解密报错:pad block corrupted 解决方法 微信小程序获取用户手机号,后端解密手机号的时候偶尔会报错 javax.crypto.BadPaddingException: ...

  7. 微信小程序获取手机号,java解密报错

    临时帮朋友解决这个bug花了一下午时间,出坑以后赶紧给各位爷写一篇文章,心累.. 在此之前先测一下你的程序有没有问题,如果程序有问题,先去底部把我的代码拿走: String encryptedData ...

  8. java cipher用法_java使用Cipher 执行RSA解密报错

    padding选取都是一样的,加密成功,解密失败,很奇怪. #主要代码 public static byte[] rsa_encrypt(byte[] bArr, byte[] bArr2) { tr ...

  9. AES加密报错:Illegal key size or default parameters或希望支持32位密钥

    今天在接一个中·宣部文档时用到了AES128加密,对方给的密钥是32位的,方法写完运行时报该错误,如下: 问题原因jdk自带的加密包,不支持32位密钥加密,需要下载jar包替换掉 需要替换的jar包: ...

最新文章

  1. 装管家婆系统要开启那些服务器,管家婆服务器维护注意的一些事项?
  2. wdcp-apache开启KeepAlive提高响应速度
  3. php怎么上传函数,php上传函数怎么封装
  4. [读书笔记]Effective Java 第四章
  5. 解读 2018之Go语言篇(下):明年有哪些值得期待?
  6. 乐高百变工程旋转飞椅知识点_每日一个知识点:关于磁盘的一些事儿
  7. NATSserver配置具体解释
  8. 现在大厂面试,也太太太太太难了吧!
  9. linux重定向命令语法,linux重定向命令应用及语法
  10. Programer Cat 福利
  11. 如何使用计算机文件共享,两台电脑如何共享文件?【步骤图解】
  12. 修改移动硬盘盘符(G盘--E盘)
  13. 非常有意思的Flowlet
  14. 笔记(待续)-基于梯度下降法的RBF神经网络控制
  15. ChatGPT聊天机器人如何发图片????
  16. 尝试投了下 OR 被拒,领教了顶级期刊的审稿
  17. python轮子下载教程
  18. cocos2d-html5 游戏实战源代码大集合和下载(包括flappy,popstar等----持续更新中----)...
  19. 深度学习数学基础-概率与信息论
  20. [RK3288][Android6.0] PWM backlight 驱动流程小结

热门文章

  1. Android 节操视频播放器jiecaovideoplayer使用
  2. SSM项目实例——简易版图书管理系统
  3. uni-app中的生命周期钩子函数
  4. iis搭建ftp服务器及身份验证设置
  5. 寒假收获(2015.1.16)
  6. python开发要学哪些内容_Python开发工程师需要学习哪些内容?
  7. iPhone/iPad/Touch苹果设备型号对应名称表
  8. 监督学习、无监督学习、半监督学习和强化学习
  9. laravel从入门到精通之 php excel设置单元格边框只显示竖条
  10. 常见前端九十道面试题及答案-韩烨