@RequestParam 参数偶尔丢失

改动过一版代码之后, 发现@RequestParam注解的参数经常丢失.

  1. 首先确认前端确实把参数传过来了,
  2. 用curl直接请求接口, 发现有时候会出现参数丢失, 重启后再用curl请求某个丢失参数的接口, 无论怎么重试都不会有问题.

没办法了, 只好去跟tomcat的源码, 因为@RequestParam的参数会从request.getParameterMap()方法里取对应的值, 然后打个断点看tomcat怎么获取的
在这里插入图片描述
最终跟到这个类里, 实现方法
在这里插入图片描述
最终走到coyoteRequest的getParameters方法, 实现很简单
在这里插入图片描述
然后getParameterNames();
在这里插入图片描述
最终处理查询参数
在这里插入图片描述
最终就是从queryMB这个参数解析出来, 这个queryMB就是请求时传过来的参数,
那就看看当getParameterMap为空的时候, queryMB是否为空, 来判定tomcat一定是接到了参数
在这里插入图片描述
然后发现queryMB有值, 但是似乎好像上面的方法没有把这个参数解析出来, 开始怀疑一定是某个接口改了什么东西, 因为Request是可以被循环利用的, 但是这个request被再次使用一定是请求结束了, 后来怀疑是使用了deferedResult, 但也被排除了, 因为deferedResult会使用servlet3.0以上的异步方式, request不会被提前循环使用, 百思不得其解的时候同时搜到了一篇文章
https://blog.csdn.net/Mr_SeaTurtle_/article/details/79274748 (手动给作者点赞)
豁然开朗,(后来发现有一个导入功能比较耗时, 被放在了一个纯异步的方法里, 访问的方法里有一个方法被切面切掉了, 并且里面获取了request.getParameter)
request可以传递到异步线程, 但要保证在请求返回之前访问, 如deferedResult set值之前. (为了避免这种情况,还是尽量不要传到异步线程里了).

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值