shiro.crypto.CryptoException: Unable to correctly extract the Initialization Vector or ciphertext

article/2025/9/23 0:27:24

错误

工程中使用了shiro,最近启动工程后通过接口访问就一直在报错,跟踪了一下源码,发现是cookie导致的。错误如下:

org.apache.shiro.crypto.CryptoException: Unable to correctly extract the Initialization Vector or ciphertext.
at org.apache.shiro.crypto.JcaCipherService.decrypt(JcaCipherService.java:378)
at org.apache.shiro.mgt.AbstractRememberMeManager.decrypt(AbstractRememberMeManager.java:489)
at org.apache.shiro.mgt.AbstractRememberMeManager.convertBytesToPrincipals(AbstractRememberMeManager.java:429)
at org.apache.shiro.mgt.AbstractRememberMeManager.getRememberedPrincipals(AbstractRememberMeManager.java:396)
at org.apache.shiro.mgt.DefaultSecurityManager.getRememberedIdentity(DefaultSecurityManager.java:604)
at org.apache.shiro.mgt.DefaultSecurityManager.resolvePrincipals(DefaultSecurityManager.java:492)
at org.apache.shiro.mgt.DefaultSecurityManager.createSubject(DefaultSecurityManager.java:342)
at org.apache.shiro.subject.Subject$Builder.buildSubject(Subject.java:846)
at org.apache.shiro.web.subject.WebSubject$Builder.buildWebSubject(WebSubject.java:148)
at org.apache.shiro.web.servlet.AbstractShiroFilter.createSubject(AbstractShiroFilter.java:292)
at org.apache.shiro.web.servlet.AbstractShiroFilter.doFilterInternal(AbstractShiroFilter.java:359)
at org.apache.shiro.web.servlet.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:125)
at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:344)
at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:261)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208)
at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:88)
at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:220)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:122)
at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:505)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:170)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:103)
at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:957)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:116)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:423)
at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1079)
at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:620)
at org.apache.tomcat.util.net.AprEndpoint$SocketProcessor.doRun(AprEndpoint.java:2476)
at org.apache.tomcat.util.net.AprEndpoint$SocketProcessor.run(AprEndpoint.java:2465)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)
at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
at java.lang.Thread.run(Thread.java:744)
Caused by: java.lang.ArrayIndexOutOfBoundsException
at java.lang.System.arraycopy(Native Method)
at org.apache.shiro.crypto.JcaCipherService.decrypt(JcaCipherService.java:370)
... 35 more

分析

    /*** Default constructor that initializes a {@link DefaultSerializer} as the {@link #getSerializer() serializer} and* an {@link AesCipherService} as the {@link #getCipherService() cipherService}.*/public AbstractRememberMeManager() {this.serializer = new DefaultSerializer<PrincipalCollection>();AesCipherService cipherService = new AesCipherService();this.cipherService = cipherService;// 默认构造方法调用时,生成新的密钥setCipherKey(cipherService.generateNewKey().getEncoded());}

   shiro底层有一个AbstractRememberMeManager的抽象实现,它是这个错误的罪魁祸首,服务端在接收cookie时,得到rememberMe的cookie值=>Base64解码=>AES解密=>反序列化(未限制)。
   shiro≤1.2.4版本预设使CookieRememberMeManager,由于AES使用的key泄露,导致反序化的cookie可控,从而引发反序化攻击。而且AbstractRememberMeManager的构造方法中每次都会重新生成对称加密密钥,意味着每次重启工程都会重新生成一对加解密密钥。这就会导致第一次启动工程shiro使用A密钥加密了cookie,第二次启动工程shiro重新生成了密钥B,当用户访问页面时,shiro会用密钥B去解密上一次用密钥A加密的cookie,导致解密失敗,形成报错,所以这不影响使用者登入操作(rememberMe失效罢了),所以这种异常只会在工程重启(shiro清除session)第一次开启页面的时候出现。

解决方案

1.升级shiro版本,shiro>1.2.4之后这个问题有相应的解决措施。
2.配置固定密钥,这种方法不建议,容易泄露。
3.最简单的方式,直接删除浏览器cookie。
以谷歌浏览器为例,直接找到cookie进行删除即可。

在这里插入图片描述
shiro文档可参考: https://shiro.apache.org/web.html#Web-RememberMeServices


http://chatgpt.dhexx.cn/article/v0bdm42j.shtml

相关文章

Bugku CRYPTO No Ciphertext RSA writeup by 树木

前言 菜鸡树木出的新密码题&#xff0c;质量不高&#xff0c;大佬们不要喷呜呜呜 题目信息 题目名称&#xff1a;No Ciphertext RSA 题目作者&#xff1a;树木有点绿 描  述: The ciphertext is unknown! 解题过程 通过观察发现题目给了dp&#xff0c;那么我们可以根据…

某cpws - ciphertext加密与数据解密

前言 本文仅用于学术交流。 学习探讨逆向知识,欢迎私信共享学习心得。 如有侵权,联系博主删除。 请勿商用,否则后果自负。 加密位置确定 网站 : aHR0cHMlM0EvL3dlbnNodS5jb3VydC5nb3YuY24vd2Vic2l0ZS93ZW5zaHUvMTgxMjE3Qk1US0hOVDJXMC9pbmRleC5odG1sJTNGcGFnZUlkJTNENTU2…

《A Traceable and Revocable Ciphertext-Policy Attribute-based Encryption Scheme Based》属性加密机制

《基于隐私保护的可追溯性和可撤销的密文策略属性加密》 论文链接&#xff1a;A Traceable and Revocable Ciphertext-Policy Attribute-based Encryption Scheme Based 1.可追踪和可撤销指的是什么&#xff1f; 可撤销性 用户撤销&#xff1a;撤销特定用户的所有属性&…

属性基加密仿真及代码实现(CP-ABE)论文:Ciphertext-Policy Attribute-Based Encryption

1、仿真论文&#xff1a;Ciphertext-Policy Attribute-Based Encryption 2、使用库&#xff1a;JPBC lombok 3、目录结构&#xff1a; 3.1 essay&#xff1a;论文 3.2 lib&#xff1a;jpbc库 3.3 params&#xff1a;椭圆曲线参数 3.4 src&#xff1a;源码 attribute&…

论文翻译—Ciphertext-Policy Attribute-Based Encryption

Abstract 在一些分布式系统中&#xff0c;只有当用户拥有一组特定的凭证或属性时&#xff0c;用户才能访问数据。目前&#xff0c;实施这种策略的唯一方法是使用一个受信任的服务器来存储数据并协调访问控制。但是&#xff0c;如果存储数据的任何服务器被泄露&#xff0c;那么数…

华为实习密文cipherText破解

很多小伙伴找我破解密文&#xff0c;但是最近比较忙&#xff0c;所以决定公布破解密文的程序。 连接如下&#xff1a;华为实习密文cipherText破解 分割线以下为之前的内容 前段时间面试了华为实习生&#xff0c;还在等待offer中。 之前一直可以通过一个网址查看进展&#x…

某某行政处罚文书网 (请求参数: ciphertext)

前言 本文仅用于学术交流。 学习探讨逆向知识,欢迎私信共享学习心得。 如有侵权,联系博主删除。 请勿商用,否则后果自负。 浅聊一下 该网站文书列表页请求时,会携带一个post参数ciphertext,这个参数在一定时间范围内是不变的,但是是有实效性的, 有效期大概在两个小时…

十七届全国大学生智能车竞赛华南赛区开幕式议程

十七届全国大学生智能车竞赛 华南赛区开幕式议程 开幕式时间&#xff1a;2022年7月25日&#xff0c;上午8&#xff1a;30开幕式地址&#xff1a;哈尔滨工业大学&#xff08;深圳&#xff09;活动中心 开幕式议程&#xff1a; 一、介绍参加会议的嘉宾二、奏国歌三、嘉宾致辞 …

全国大学生智能车竞赛 |掀桌子的时候

01 掀桌子 又到了掀桌子的时候了 一、掀桌子 每年一度的全国大学生智能车竞赛竞赛到了这个时候&#xff0c;  都开始进入掀桌子的周期了。 参加过一届比赛的同学开始纷纷给组委会提出比赛内容的建议。  这不&#xff0c; 刚刚看到同学在后台的一个留言&#xff0c;  着实把我…

第十五届全国大学生智能车竞赛各分赛区赛道数量以及比赛系统数量

作者:卓晴博士 全国大学生智能车竞赛秘书处 2020-07-26 Sunday □ 各分赛区赛道数量 赛区比赛时间东北8月15-17日华北8月11-13日华东8月23-26日华南8月15-20日西部8月12-14日安徽11月前后山东8月12-15日浙江8月9-11日 □ 各分赛区所需要比赛系统数量 今年举办集中线下比赛的赛区…

时雨月五| AI机器学习实战の电磁导航智能车中神经网络应用的问题与思考

“不愤不启&#xff0c;不悱不发。举一隅不以三隅反&#xff0c;则不复也”。 – 《论语述而》 再次将论语中的这句“不愤不启&#xff0c;不悱不发”引用在这里&#xff0c;说明学生的学习的活动部分来自老师&#xff0c;大部分来自于自己主动的“愤”“悱”&#xff0c;否则…

第十五届全国大学生智能车竞赛室外光电创意组别进入线下比赛的队伍名单

作者:卓晴博士&#xff0c;清华大学自动化系 更新时间&#xff1a;2020-08-05 Wednesday 第十五届全国大学生智能车竞赛组委会在7月4日公布了室外光电ROS预赛方案 &#xff0c;截止到7月20日&#xff0c;公布到213支队伍的の报名信息&#xff0c;经过核实去重之后&#xff0c;最…

国赛来咯,全国大学生智能汽车竞赛百度赛道正式开启

「第17届全国大学生智能汽车竞赛—完全模型组竞速赛」1月15日全面启航&#xff01;大赛组委会秘书长卓晴教授届时将亲临百度飞桨直播间&#xff0c;和同学们一起聊备赛&#xff0c;话今年。 01 竞赛简介 「全国大学生智能汽车竞赛」是教育部倡导的大学生科技A类竞赛&#xff…

电解电容为什么会爆炸?

关注星标公众号&#xff0c;不错过精彩内容 作者 | 卓晴 来源 | TsinghuaJoking 一、电解电容 电解电容是通过电解质作用在电极上形成的氧化层作为绝缘层的电容&#xff0c;通常具有较大的容量。电解质是液体、胶冻状富含离子的物质&#xff0c;大多数电解电容都是有极性的&…

从150kHz 到 150MHz漫谈智能车竞赛中的无线导航技术

简 介&#xff1a; 这个文章来自于太原理工大学萧老师给智能车竞赛无线导航方案的建议。 关键词&#xff1a; 智能车竞赛&#xff0c;导航&#xff0c;无线电&#xff0c;萧老师 卓晴老师你好&#xff01; 节能信标组利用信标发出的信号对信标定位。用摄像头定位比较容易实现。…

Bootstrapvalidator表单验证+ 模态框 Ajax请求 Demo

BooStrapValidator网络引用地址:http://www.bootcdn.cn/bootstrap-validator/ BooStrapValidator文件下载 gitHub地址https://github.com/nghuuphuoc/bootstrapvalidator/ 这里模拟了一个后台数据返回,即请求url 为 validator.json&#xff0c;该文件内容为 false&#xff0c;…

一位刚刚成功上岸的智能车队员对于参赛经历总结与对比赛的建议

简 介&#xff1a; 尊敬的卓晴老师您好&#xff0c;我是江苏理工学院2017级本科毕业生&#xff0c;也是北京科技大学2021级研究生&#xff0c;本科期间做了整整四年智能车&#xff0c;分享一些比赛经历和对十七届全国大学生智能汽车竞赛的建议。 关键词&#xff1a; 智能车竞赛…

2022新生相关工作

简 介&#xff1a; 本文给出2022年新生相关工作的重点内容。 关键词&#xff1a; 2022&#xff0c;新生 #mermaid-svg-AUYC0UwdrejLh3M9 {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-AUYC0UwdrejLh3M9 .error-ico…

信号采样混叠/混频

信号采样混叠 0、使用AD5933分析复阻抗的时钟频率设置_卓晴的博客-CSDN博客 频率混叠是怎样产生的&#xff0c;有什么解决办法&#xff1f; 答&#xff1a;(1)当采用过大的采样间隔&#xff34;&#xff53;对两个不同频率的正弦波采样时&#xff0c;将会得到一组相同的采样…

第十七届全国大学生智能汽车竞赛东北赛区 开幕式会序

第十七届全国大学生智能汽车竞赛东北赛区 开幕式会序 一、时 间 2022年7月29日&#xff08;星期五&#xff09;8:30 二、会议形式 腾讯会议&#xff1a;714-279-XXX 三、特邀嘉宾 沈阳航空航天大学党委副书记、校长 孙小平清华大学自动化系党委书记 张 佐全国大学生智…