一、场景
? 第一次搭建项目开发环境,需要在项目中实现日志拦截器,用来获取用户请求参数日志,以便在后期维护中出现BUG时能够快速定位错误发生的场景。请求参数一般通过GET和POST方式进行传递,GET请求参数获取通过request.getParameterMap()获取。而POST请求参数则采用request.getInputStream()获取。
二、错误
? 在实现中发现如果通过流获取参数,控制器中@RequestBody注解参数则获取不到。查看资料后,了解到spring中request.getInputStream() 和request.getReader()只能被获取一次,而@RequestBody注解参数的底层实现也是通过流来获取请求参数的。因此才出现了拦截器中通过流获取参数后,控制器中获取参数报错。
三、解决方案
1、日志拦截器类
2、自定义一个HttpServletRequestWrapper子类,用来封装HttpServletRequest请求
3、自定义一个过滤器将自定义的请求封装类传下去
?