日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

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

發(fā)布時(shí)間:2024/3/13 编程问答 34 豆豆
生活随笔 收集整理的這篇文章主要介紹了 AES解密报错,Input length must be multiple of 16 when decrypting with padded cipher 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

項(xiàng)目場景:對登錄用戶名、密碼前端加密,后端解密失敗


問題描述

在做login登錄頁面的用戶名和密碼加密時(shí),前端加密后端解密,但是拋出報(bào)錯:Input length must be multiple of 16 when decrypting with padded cipher,仔細(xì)檢查過偏移向量,沒有問題,但還是不行,于是在后端測試,先加密,后解密,測試發(fā)現(xiàn)一切正常,那問題就應(yīng)該出現(xiàn)在傳參上面,應(yīng)該是字符轉(zhuǎn)義的問題;

這是前端傳入的加密后的用戶名和密碼

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

原因分析:

前端enCode在后端解析失敗,最后的%3D無法解析,導(dǎo)致偏移向量對應(yīng)不上,報(bào)錯


解決方案:

----------------------------------------解決方案---------------------------------------String un="8RKHWcE11foCm2%2BaEuFG6w%3D%3D";String pd="TQafftXrh8aXYNFJcPgw1w%3D%3D";//先轉(zhuǎn)編碼!!!String ufUserName = URLDecoder.decode(un, "UTF-8");String ufPassWord = URLDecoder.decode(pd, "UTF-8");//此時(shí)里面的%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,補(bǔ)碼方式為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* 需要加密的內(nèi)容* @param key* 加密密碼* @return*/public static String encrypt(String content, String key) {try {// 構(gòu)造密鑰SecretKeySpec skey = new SecretKeySpec(key.getBytes(), algorithm);// 創(chuàng)建初始向量iv用于指定密鑰偏移量(可自行指定但必須為128位),因?yàn)锳ES是分組加密,下一組的iv就用上一組加密的密文來充當(dāng)IvParameterSpec iv = new IvParameterSpec(key.getBytes(), 0, offset);// 創(chuàng)建AES加密器Cipher cipher = Cipher.getInstance(transformation);byte[] byteContent = content.getBytes(charset);// 使用加密器的加密模式cipher.init(Cipher.ENCRYPT_MODE, skey, iv);// 加密byte[] result = cipher.doFinal(byteContent);// 使用BASE64對加密后的二進(jìn)制數(shù)組進(jìn)行編碼return new Base64().encodeAsString(result);} catch (Exception e) {logger.info("", e);}return null;}/*** AES(256)解密** @param content* 待解密內(nèi)容* @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);// 解密時(shí)使用加密器的解密模式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));//// }

具體解決就是:在解密前再轉(zhuǎn)一次編碼,基本就能解決這一報(bào)錯問題。

總結(jié)

以上是生活随笔為你收集整理的AES解密报错,Input length must be multiple of 16 when decrypting with padded cipher的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。