HttpServletRequest参数丢失问题及解决

 更新时间:2025年10月31日 09:55:15   作者:呼哇呼哇time  
在使用HttpServletRequest进行参数传递时,如果在异步方法中使用,可能会导致参数丢失,这是因为HttpServletRequest对象在异步任务中可能被回收,为了解决这个问题,可以在异步方法中提前提取参数,然后将其传递给异步任务

HttpServletRequest参数丢失

遇到一个奇怪的问题

测试环境没有出现,本地连正式数据库也没复现。

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

已知列表分页查询是没有问题的

筛选条件都能生效,代码如下:

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

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

按常理推断

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

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

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

细心的网友可能注意到了

我们导出方式是异步的,关键在@Async注解

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

比较官方的说明

不推荐在异步中使用request,会得到不确定的结果

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

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

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • springboot开发扩展springmvc实现解析

    springboot开发扩展springmvc实现解析

    这篇文章主要介绍了springboot开发扩展springmvc实现解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-02-02
  • MyBatis实现动态SQL更新的代码示例

    MyBatis实现动态SQL更新的代码示例

    本文博小编将带领大家学习如何利用 MyBatis 拦截器机制来优雅的实现这个需求,文中通过代码示例介绍的非常详细,具有一定的参考价值,需要的朋友可以参考下
    2023-07-07
  • springboot断言异常封装与统一异常处理实现代码

    springboot断言异常封装与统一异常处理实现代码

    异常处理其实一直都是项目开发中的大头,但关注异常处理的人一直都特别少,下面这篇文章主要给大家介绍了关于springboot断言异常封装与统一异常处理的相关资料,需要的朋友可以参考下
    2023-01-01
  • spring使用ehcache实现页面缓存示例

    spring使用ehcache实现页面缓存示例

    这篇文章主要介绍了spring使用ehcache实现页面缓存示例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-02-02
  • Jmeter参数化实现方法及应用实例

    Jmeter参数化实现方法及应用实例

    这篇文章主要介绍了Jmeter参数化实现方法及应用实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-08-08
  • SpringBoot+Mybatis实现登录注册的示例代码

    SpringBoot+Mybatis实现登录注册的示例代码

    这篇文章主要介绍了SpringBoot+Mybatis实现登录注册的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-03-03
  • SpringMVC JSON数据传输参数超详细讲解

    SpringMVC JSON数据传输参数超详细讲解

    有时候参数的传递还需要更多的参数,比如一个获取用户信息的请求中既有用户ID等基本参数,还要求对查询结果进行分页,针对这种场景,一般都会将分页参数封装成一个对象,然后将它和基本参数一起传给控制器
    2023-02-02
  • jdk8的datetime时间函数使用示例

    jdk8的datetime时间函数使用示例

    这篇文章主要介绍了jdk8的datetime时间函数使用示例,需要的朋友可以参考下
    2014-03-03
  • Java RabbitMQ的持久化和发布确认详解

    Java RabbitMQ的持久化和发布确认详解

    这篇文章主要为大家详细介绍了RabbitMQ的持久化和发布确认,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-03-03
  • mybatis查询到了数据,但是实体类个别字段为null问题

    mybatis查询到了数据,但是实体类个别字段为null问题

    这篇文章主要介绍了mybatis查询到了数据,但是实体类个别字段为null问题及解决,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-01-01

最新评论