美文网首页
HttpServletRequest参数丢失

HttpServletRequest参数丢失

作者: little多米 | 来源:发表于2022-09-27 17:05 被阅读0次

    遇到一个奇怪的问题,测试环境没有出现,本地连正式数据库也没复现。

    主要业务逻辑是通过筛选条件从数据库导出一批数据。异常情况是,选择的筛选条件失效了,导致导出了全量数据,这搞不好会有数据泄露风险。

    已知列表分页查询是没有问题的,筛选条件都能生效,代码如下:

    但是导出时却没起作用,导出代码:

    观察可知,他们都调用的getSqlMap方法,该方法具体作用就是从HttpServletRequest中获取相关条件参数,并放到Map中,供后续查询代码使用,如下:

    按常理推断,输入和代码一致,得到的结果应该是一致的,但是却不是这样

    使用jvm神器arthas,watch一下getSqlMap方法,然后分别调用列表查询导出接口,得到如下两条记录

    对比可知,上面有的很多参数,下面一条都没有,那么参数怎么会消失呢?数据都是从HttpServletRequest对象中获取的,那么这个对象里面的数据怎么消失了呢?

    细心的网友可能注意到了,我们导出方式是异步的,关键在@Async注解

    难道莫非,HttpServletRequest被回收了,果然网上搜一下,很多案例

    比较官方的说明,不推荐在异步中使用request,会得到不确定的结果

    因此,我们需要在异步方法前提取参数,再传入

    小小的问题,大大的疑惑。花了不少时间定位问题,好在爬出了坑。

    相关文章

      网友评论

          本文标题:HttpServletRequest参数丢失

          本文链接:https://www.haomeiwen.com/subject/lbafartx.html