IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> Java知识库 -> 记录一次:UT010034: Stream not in async mode -> 正文阅读

[Java知识库]记录一次:UT010034: Stream not in async mode

今天写了一个导出接口,很正常的导出:

@GetMapping(value = "/exportSalesOrder")
public void export(Param param, HttpServletResponse response) throws IOException {

}

就这样一个正常的导出,但是突然报错了。

{
"id": "a500fd6c-426f-478e-a8fa-969544c57ece",
"code": 500,
"message": "java.lang.IllegalStateException: UT010034: Stream not in async mode",
"subCode": null,
"subMessage": null,
"data": null,
"errors": null,
"stackTraceElementList": null,
"stackTraceInfo": null
}

百思不得其解,怎么就UT010034了,百度了一圈,都是在说异步问题,我也没用异步。只能靠自己了。
一步步排查:

首先,我们项目框架里有日志拦截打印的,

会判断 入参是不是HttpServletRequest或者HttpServletResponse的,如果是就不打印入参,如果是其他自定义参数会打印出来

?直接报错的点就是这里,打印入参。为什么导出的入参有HttpServletResponse,到这里是会过滤掉的,不会去jsonToString的,应该不会报错把。
接下来:

?

?上图是我找了另外的导出的HttpServletResponse,下图是我报错的导出的HttpServletResponse,可以看出来,上下两个图的HttpServletResponse实际对象是不一样的。上图能过滤的是HttpServletResponse,下图不能过滤的是CounterServletResponseWrapper对象。这就是为什么到了jsonToString的时候报错了,因为jsonToString不能String出CounterServletResponseWrapper这个对象,所以会报错。

那为什么下图的HttpServletResponse的实际对象是CounterServletResponseWrapper呢。
继续深入,

点开CounterServletResponseWrapper这个类,一直进去

?会发现CounterServletResponseWrapper这个实际实现了HttpServletResponse,所以CounterServletResponseWrapper是HttpServletResponse的子类实现类。

然后由于我们底层的日志拦截器没有对CounterServletResponseWrapper这个排除过滤,所以导致不能toString,导致报错。

继续排查,为什么会有CounterServletResponseWrapper这个类呢,这个类在哪呢

可以看到,这个类是在javamelody-spring-boot-starter这个包里。

net.bull.javamelody:javamelody-spring-boot-starter:1.87.0

这个包在项目里有引入,看记录是被引入了很久了,前人引入的,实际没用到,就是一个多余的包。

把这个包去掉,HttpServletResponse就回归正常了。就可以正常的被底层的日志拦截过滤了。

  Java知识库 最新文章
计算距离春节还有多长时间
系统开发系列 之WebService(spring框架+ma
springBoot+Cache(自定义有效时间配置)
SpringBoot整合mybatis实现增删改查、分页查
spring教程
SpringBoot+Vue实现美食交流网站的设计与实
虚拟机内存结构以及虚拟机中销毁和新建对象
SpringMVC---原理
小李同学: Java如何按多个字段分组
打印票据--java
上一篇文章      下一篇文章      查看所有文章
加:2022-05-08 07:54:27  更:2022-05-08 07:56:29 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 0:23:17-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码