a) Spring MVC属于SpringFrameWork的后续产品,已经融合在Spring Web Flow里面。Spring 框架提供了构建 Web 应用程序的全功能 MVC 模块。使用 Spring 可插入的 MVC 架构,从而在使用Spring进行WEB开发时,可以选择使用Spring的SpringMVC框架或集成其他MVC开发框架,如Struts1(现在一般不用),Struts2等。
i. 用户发送请求至前端控制器DispatcherServlet
ii. DispatcherServlet收到请求调用HandlerMapping处理器映射器。
iii. 处理器映射器根据请求url找到具体的处理器,生成处理器对象及处理器拦截器(如果有则生成)一并返回给DispatcherServlet。
iv. DispatcherServlet通过HandlerAdapter处理器适配器调用处理器
v. 执行处理器(Controller,也叫后端控制器)。
vi. Controller执行完成返回ModelAndView
vii. HandlerAdapter将controller执行结果ModelAndView返回给DispatcherServlet
viii. DispatcherServlet将ModelAndView传给ViewReslover视图解析器
ix. ViewReslover解析后返回具体View
x. DispatcherServlet对View进行渲染视图(即将模型数据填充至视图中)。
xi. DispatcherServlet响应用户
3. SpringMvc常用配置
a) 开启注解扫描:springmvc使用<mvc:annotation-driven>自动加载RequestMappingHandlerMapping和RequestMappingHandlerAdapter,可用在springmvc.xml配置文件中使用<mvc:annotation-driven>替代注解处理器和适配器的配置。
b) 静态资源加载:[XML] 纯文本查看 复制代码
<!-- 静态资源访问 -->
<mvc:resources location="/img/" mapping="/img/**" />
<!-- mapping:映射,location:本地资源路径,一定要是webapp根目录下,注意必须是webapp根目录下的路径。 **,它表示映射/img/下的所有文件 -->
c) 视图解析器配置:[XML] 纯文本查看 复制代码
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="viewClass"
value="org.springframework.web.servlet.view.JstlView" />
<property name="prefix" value="/WEB-INF/jsp/" />
<property name="suffix" value=".jsp" />
</bean>
<!-- InternalResourceViewResolver:支持JSP视图解析
viewClass:JstlView表示JSP模板页面需要使用JSTL标签库,所以classpath中必须包含jstl的相关jar 包。此属性可以不设置,默认为JstlView。
prefix 和suffix:查找视图页面的前缀和后缀,最终视图的址为:
前缀+逻辑视图名+后缀,逻辑视图名需要在controller中返回ModelAndView指定,比如逻辑视图名为hello,则最终返回的jsp视图地址 “WEB-INF/jsp/hello.jsp”-->
1. 参数绑定
a) 默认支持的数据类型
i. 整形:Integer、int
ii. 字符串:String
iii. 单精度:Float、float
iv. 双精度:Double、double
v. 布尔型:Boolean、boolean
1. 说明:对于布尔类型的参数,请求的参数值为true或false。
b) 使用pojo接收表单数据
i. 如果提交的参数很多,或者提交的表单中的内容很多的时候可以使用pojo接收数据。要求pojo对象中的属性名和表单中input的name属性一致。
ii. 注意:提交的表单中不要有日期类型的数据,否则会报400错误。如果想提交日期类型的数据需要用到后面的自定义参数绑定的内容。
iii.
Post提交乱码解决 <filter-name>CharacterEncodingFilter</filter-name>
<filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
<init-param>
<param-name>encoding</param-name>
<param-value>utf-8</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>CharacterEncodingFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>