两次接口都是成功了的,但是第一次请求的返回值没有数据,状态为200.
最开始我都认为是前端调用的问题,两次请求之间加上延时还是不行。我自己写了个脚本测试也是如此,通过反复测试,发现如果当第一次请求没有执行完之前,发起第二次请求,那么第一次请求就绝对没有数据,但也是请求成功的。
这个接口稍微有点特殊,普通的接口直接返回一个DTO给前端,由于这个接口的数据格式比较灵活,所以直接处理成Gson,通过response对象写入。
public class BaseController {
protected HttpServletRequest request;
protected HttpServletResponse response;
protected HttpSession session;
@ModelAttribute
public void setReqAndRes(HttpServletRequest req, HttpServletResponse res) {
this.request = req;
this.response = res;
this.session = req.getSession();
}
}
为了获取response对象,我让我的controller继承了这个BaseController,response则成为了controller的一个属性。当同时两次执行时,这种方式获取到的response对象应该是同一个,controller是单例的。
private HttpServletResponse getResponse(){
ServletRequestAttributes servletRequestAttributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();
if (ObjectUtils.isEmpty(servletRequestAttributes)) {
throw new BusinessException(BusinessCodeEnum.FAIL.getCode(), "Failed to get response object", "获取response对象失败");
}
return servletRequestAttributes.getResponse();
}
将获取response对象的方式换成后面这一种,简单测试一下就发现问题解决了。