继承HandlerInterceptor用的异步请求处理开始之后调用的回调方法。
当处理程序开始的异步请求, DispatcherServlet退出,而不调用postHandle和afterCompletion因为它通常不用于同步请求,由于请求处理的结果(例如ModelAndView的)可能还没有准备好,将被从另一个线程同时产生的。 在这样的场景, afterConcurrentHandlingStarted代替调用,从而允许实现来执行任务,例如释放线程Servlet容器之前清理线装属性。
当异步处理完成时,请求被调度到用于进一步处理的容器。 在这个阶段, DispatcherServlet调用preHandle , postHandle和afterCompletion 。 到初始请求和异步处理完成之后后续的调度之间进行区分,拦截器可以检查是否javax.servlet.DispatcherType的javax.servlet.ServletRequest是"REQUEST"或"ASYNC" 。
需要注意的是HandlerInterceptor的实现可能需要做的工作,当一个异步请求超时,或者完成与网络错误。 对于这样的情况下,Servlet容器不会调度,因此postHandle和afterCompletion方法将不会被调用。 相反,拦截器可以注册来跟踪通过的异步请求registerCallbackInterceptor和registerDeferredResultInterceptor上的方法WebAsyncManager 。 这可以主动地从每一个请求进行preHandle不管异步请求处理是否将开始。
以来:
3.2
也可以看看:
org.springframework.web.context.request.async.WebAsyncManager , org.springframework.web.context.request.async.CallableProcessingInterceptor , org.springframework.web.context.request.async.DeferredResultProcessingInterceptor