业务场景:使用Filter做接口的登录状态Token验证,使用request.getInputStream()获取Body体内流数据,发现再次在Cotroller层获取参数值,一直为null,导致无法获取;
查找原因:
- 一个InputStream对象在被读取完成后,将无法被再次读取,始终返回-1;
- InputStream并没有实现reset方法(可以重置首次读取的位置),无法实现重置操作;
因此,当自己写的Filter中调用了一次getInputStream()
后,后面再调用getInputStream()
读取的数据都为空,导致接口异常。
解决办法:
- 缓存数据。
代码:
在Filter中调用request.getInputStream()获取数据后,马上用request.setAttribute("body", body);缓存数据,
String body = IOUtils.toString(request.getInputStream()); request.setAttribute("body", body);
然后在接口获取缓存数据
Object body = request.getAttribute("body"); String requestStr = String.valueOf(body);