-
Spring MVC 中,请求会首先通过一个单实例的前端控制器--DispatcherServlet,它的任务是查询处理器映射(handler mapping),并将请求发送给 Spring MVC 控制器(controller)。
-
经过逻辑处理产生的信息被称作模型(model)。控制器获取用户提交的信息,将逻辑处理后得到的模型数据打包,并标示出用于渲染输入的视图名,发送到 DispatcherServlet。良好的控制器本身只处理很少甚至不处理工作,而将业务逻辑委托给一个或多个服务对象。
-
DispatcherServlet 使用视图解析器(view resolver) 将视图名匹配为特定的视图实现,交付模型数据。视图使用模型数据渲染输出,通过相应对象传递给客户端。
-
借助 Servlet3 规范和 Spring3.1 的功能增强,可以使用 Java 将 DispatcherServlet 配置在 Servlet 容器中,而不使用 web.xml。
-
扩展
AbstractAnnotationConfigDispatcherServletInitializer
的任意类会自动配置 DispatcherServlet 和 Spring 应用上下文。 -
扩展类的
getServletMappings()
方法将一个或多个路径映射到 DispatcherServlet 上。/
表示它会是应用的默认 Servlet,处理进入应用的所有请求。 -
DispatcherServlet 启动时会创建 Spring 应用上下文。扩展类的
getServletConfigClasses()
方法定义 DispatcherServlet 加载的应用上下文时,加载在方法中添加的配置类的 bean(包含 web 组件的 bean,如控制器、视图解析器等)。 -
DispatcherServlet 加载包含 web 组件的 bean,而 ContextLoaderListener 要加载应用中的其他 bean。如驱动应用后端的中间层和数据层组件。
-
扩展类的
getServletConfigClasses()
方法通过返回带有@Configuration
注解的类(WebConfig)来定义 DispatcherServlet 应用上下文中的 bean,扩展类的getRootConfigClasses()
方法通过返回带有@Configuration
注解的类(RootConfig)来配置 ContextLoaderListener 创建的应用上下文中的 bean。 -
通过
AbstractAnnotationConfigDispatcherServletInitializer
来配置 DispatcherServlet 是传统 web.xml 方式的替代方案,只能部署到支持 Servlet3.0 的服务器中,如 Tomcat7 或更高的版本。 -
在 Spring 的 xml 配置中,可以使用
<mvc:annotation-driven>
启动注解驱动的 Spring MVC。 -
在 Java 配置中,可以使用
@EnableWebMvc
注解修饰类来启动 Spring MVC。 -
WebConfig 扩展
WebMvcConfigurerAdapter
类并重写configureDefaultServletHandling()
方法,调用DefaultServletHandlerConfigurer
的enable()
方法,要求 DispatcherServlet 将静态资源的请求转发到 Servlet 容器的默认 Servlet 上,而不使用 DispatcherServlet 本身处理此类请求。 -
在 Spring MVC 中,控制器只是在方法上添加
@RequestMapping
注解的类,注解声明了所要处理的请求。方法返回 String 类型的视图名称。 -
@Controller
注解基于@Component
注解,目的是实现组件扫描。 -
将路径转移到类级别的
@RequestMapping
上可以定义类级别的请求处理,方法上的@RequestMapping
注解会对类级别的注解进行补充。 -
@RequestMapping
注解的 value 属性可以接受一个 String 数组,用来映射到多个路径的请求。 -
在
@RequestMapping
注解修饰的方法中,可以添加 Model 类型的参数。调用 Model 的addAttribute ()
方法,将数据存入 Model 中。Model 实际上是一个 Map,会传递给视图,从而渲染到客户端。 -
如未指定
addAttribute()
的 key,模型 key 会根据数据类型推断出。如未返回视图名(直接返回了数据),逻辑视图的名称会根据请求路径推断。 -
Spring MVC 允许多种方式将客户端中的数据传递到控制器中处理,包括:查询参数(Query Parameter),表单参数(Form Parameter)和路径变量(Path Variable)。
-
@RequestParam
注解用来修饰方法中的参数,用来获取请求参数。利用注解的 defaultValue 属性,可以在未获取到请求参数时指定默认值。因请求参数都是 String 类型,所以指定的默认值需要转换为 String 类型。 -
在理想情况下,要识别资源应该通过 URL 路径进行标示,而不是查询参数。Spring MVC 允许在
@RequestMapping
的路径中添加占位符(用{}
括起来),在方法中使用@PathVariable
获取路径变量。如@PathVariable
未指定 value 值,会假设占位符名称与方法参数名相同。 -
<form>
表单未指定 action 时,会默认提交到展示时的 URL 路径上。 -
@RequestMapping
修饰的方法中,可以添加自定义类型的对象作为参数。对象的属性会使用请求中同名的参数进行填充。 -
InternalResourceViewResolver
会识别控制器方法返回字符串中的redirect:
或forward:
确定要将其解析为 重定向/前往 规则。 -
从 Spring3.0开始,Spring MVC 提供了对 Java 校验 API 的支持,而不需要特殊配置。
-
在获取请求参数的自定义类中,使用校验参数的注解,如
@NotNull
、@size(min=5, max=25)
等修饰属性,并在控制器方法参数前使用@Valid
注解开启校验功能。在控制器方法中添加 Errors 类型的参数,即可在方法中使用它的hasErrors()
方法获得校验结果。需要注意的一点,Errors 参数要紧跟在带有@Valid
注解的参数后面。
欢迎来到这里!
我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。
注册 关于