参考:
- springboot的filter执行顺序:https://blog.csdn.net/xie19900123/article/details/82082774
- springboot多filter的注册和order排序:https://blog.csdn.net/mzh1992/article/details/66970924
- 对filter的解释:http://www.runoob.com/w3cnote/filter-filterchain-filterconfig-intro.html
回过头来,我研究了半天filter,实际上下面的部分和filter没有太大的关系
最近在看设计模式的书,讲到了装饰者模式,然后想到了之前项目中的一个设计:api请求之后,需要返回一个json,这个json为了避免数据结构和结果被别人截获,数据做了加密处理。所以需要对接口的返回数据再包装一层。最后的结构应该是:
{
code:200,json:"加密后的字符串,app拿到之后做解密处理"}
正常的controller一般是直接就通过responseBody返回数据。比如用户注册,/users/sign方法,一般直接就返回注册好的用户信息
@RestController
@RequestMapping("/users")
public class UserController{
@Autowired
private IUserService userService;
/**
* 新注册用户.
* @param req
* @return
*/
@RequestMapping("/sign")
public JSONObject sign(HttpServletRequest req){
return userService.sign(req);
}
}
返回:{
user:{
id:1,name:"tom"}}
为了包装一层数据,选择使用filter的方式:
@Slf4j
@WebFilter(urlPatterns = "/*")
public class ResponseWrapperFilter extends OncePerRequestFilter {
@Override
protected void doFilterInternal(HttpServletRequest request, HttpServletResponse response, FilterChain filterChain) throws ServletException, IOException {
String uri = request.getRequestURI();
boolean pass = "/".