处理
DispatcherServlet 按如下方式处理请求
-
WebApplicationContext被搜索并作为属性绑定到请求中,以便控制器和进程中的其他元素可以使用。它默认绑定在DispatcherServlet.WEB_APPLICATION_CONTEXT_ATTRIBUTE键下。 -
区域解析器绑定到请求,以便进程中的元素可以在处理请求时(渲染视图、准备数据等)解析要使用的区域。如果您不需要区域解析,则不需要区域解析器。
-
如果您指定了多部分文件解析器,则会检查请求是否存在多部分。如果找到多部分,请求将被封装到
MultipartHttpServletRequest中,以便进程中的其他元素进一步处理。有关多部分处理的更多信息,请参阅 多部分解析器。 -
搜索合适的处理器。如果找到处理器,则运行与处理器关联的执行链(预处理器、后处理器和控制器)以准备用于渲染的模型。另外,对于注解控制器,可以在不返回视图的情况下渲染响应(在
HandlerAdapter内)。 -
如果返回模型,则渲染视图。如果没有返回模型(可能是由于预处理器或后处理器拦截了请求,可能是出于安全原因),则不渲染视图,因为请求可能已经完成。
在 WebApplicationContext 中声明的 HandlerExceptionResolver bean 用于解决请求处理期间抛出的异常。这些异常解析器允许自定义处理异常的逻辑。有关更多详细信息,请参阅 异常。
对于 HTTP 缓存支持,处理器可以使用 WebRequest 的 checkNotModified 方法,以及注解控制器的其他选项,如 控制器的 HTTP 缓存 中所述。
您可以通过在 web.xml 文件中的 Servlet 声明中添加 Servlet 初始化参数(init-param 元素)来定制单个 DispatcherServlet 实例。下表列出了支持的参数
| 参数 | 解释 |
|---|---|
|
实现 |
|
传递给上下文实例(由 |
|
|
|
当未找到请求的处理器时,是否抛出 从 6.1 开始,此属性设置为 请注意,如果也配置了默认 Servlet 处理,未解析的请求将始终转发到默认 Servlet,并且永远不会引发 404。 |