| |
|
开发:
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 { } 就这样一个正常的导出,但是突然报错了。
百思不得其解,怎么就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就回归正常了。就可以正常的被底层的日志拦截过滤了。 |
|
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
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- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |