内容概要
1.处理模型数据
2.视图和视图解析器
3.RESTful CRUD
4.SpringMVC 表单标签 &处理静态资源
处理模型数据
Spring MVC 提供了以下几种途径输出模型数据:
– ModelAndView: 处理方法返回值类型为 ModelAndView
时, 方法体即可通过该对象添加模型数据
– Map 及 Model: 入参为org.springframework.ui.Model、org.springframework.ui. ModelMap 或 java.uti.Map 时,处理方法返回时,Map中的数据会自动添加到模型中。
– @SessionAttributes: 将模型中的某个属性暂存到HttpSession 中,以便多个请求之间可以共享这个属性
– @ModelAttribute: 方法入参标注该注解后, 入参的对象就会放到数据模型中
ModelAndView
控制器处理方法的返回值如果为 ModelAndView, 则其既包含视图信息,也包含模型数据信息。
添加模型数据:
– MoelAndView addObject(String attributeName, Object attributeValue)
– ModelAndView addAllObject(Map<String, ?> modelMap)
设置视图:
– void setView(View view)
– void setViewName(String viewName)j
示例:ModelAndView
@RequestMapping("/hello2")
public ModelAndView hello() {
ModelAndView mav = new ModelAndView();
mav.addObject("name", "张三");
mav.setViewName("index");//设置请求转发到index页面
return mav;
}
Map 、 Model
Spring MVC 在内部使用了一个 org.springframework.ui.Model 接口存
储模型数据
具体步骤 :
– Spring MVC 在调用方法前会创建一个隐含的模型对象作为模型数据的存储容器。
– 如果方法的入参为 Map 或 Model 类型,Spring MVC 会将隐含模型的引用传递给这些入参。在方法体内,开发者可以通过这个入参对象访问到模型中的所有数据,也可以向模型中添加新的属性数据
@SessionAttributes
若希望在多个请求之间共用某个模型属性数据,则可以在控制器类上标注一个 @SessionAttributes, Spring MVC将在模型中对应的属性暂存到 HttpSession 中。
@SessionAttributes 除了可以通过属性名指定需要放到会话中的属性外,还可以通过模型属性的对象类型指定哪些模型属性需要放到会话中
– @SessionAttributes(types=User.class) 会将隐含模型中所有类型为 User.class 的属性添加到会话中。
– @SessionAttributes(value={“user1”, “user2”})
– @SessionAttributes(types={User.class, Dept.class})
– @SessionAttributes(value={“user1”, “user2”}, types={Dept.class})
示例:@SessionAttributes
- 向session中放数据
- value:使用Model,Map,ModelMap,ModelAndView向页面传输数据,
- 只要放置的数据的key和value指定的key一样,则会在session中同样放置一份,
- value的值为key。
- value="user"指定凡是key为user的数据都在session中放置一份
- types:只要使用Model,Map,ModelMap,ModelAndView向页面放置的数据的类型是types指定的类型,
- 则会在session中放置一份
- types= {String.class}:凡是值为String类型的,都在session中放置一份
由@SessionAttributes引发的异常
异常提示:
org.springframework.web.HttpSessionRequiredException:
Session attribute ‘user’ required - not found in session
如果在处理类定义处标注了@SessionAttributes(“xxx”),则 尝试从会话中获取该属性,并将其赋给该入参,然后再用
请求消息填充该入参对象。如果在会话中找不到对应的属性,则抛出 HttpSessionRequiredException 异常
@ModelAttribute
在方法定义上使用 @ModelAttribute 注解:Spring MVC 在调用目标处理方法前,会先逐个调用在方法级上标注了
@ModelAttribute 的方法。
在方法的入参前使用 @ModelAttribute 注解:
– 可以从隐含的模型数据中获取对象,然后将请求参数绑定到该对象中,最后再传入入参
– 可以将方法入参对象添加到模型中
示例:@ModelAttribute
@ModelAttribute("name")//@ModelAttribute注解标注在方法上,作用:在映射方法之前调用,目地是把返回值传递给映射方法入参
public String name() {
System.out.println("name");
return "张三";
}
@ModelAttribute("user")
public User user(Model model) {
System.out.println("user");
User user = new User(1, "zhangsan", "123456", "123465", 0, 18, new Date(), new Timestamp(System.currentTimeMillis()));
model.addAttribute(user);
return user;
}
@RequestMapping("/getUser")
//标注在映射方法的入参中,获取对应方法的值赋值给入参
public User getUser(@ModelAttribute("user") User user, @ModelAttribute("name") String name, Model model, HttpSession session) {
System.out.println(user);
Object u = model.getAttribute("user");
System.out.println(u);
return user;
}
执行顺序为先执行注解为@ModelAttribute的函数,当方法内的形参前使用@ModelAttribute注解时,形参从该方法获取值。
Spring MVC如何解析视图
视图和视图解析器
请求处理方法执行完成后,最终返回一个 ModelAndView
对象。对于那些返回 String,View 或 ModelMap 等类型的
处理方法,Spring MVC 也会在内部将它们装配成一个
ModelAndView 对象,它包含了逻辑名和模型对象的视图
Spring MVC 借助视图解析器(ViewResolver)得到最终的视图对象(View),最终的视图可以是 JSP ,也可能是Excel、JFreeChart 等各种表现形式的视图
对于最终究竟采取何种视图对象对模型数据进行渲染,处理器并不关心,处理器工作重点聚焦在生产模型数据的工作上,从而实现 MVC 的充分解耦
视图
视图的作用是渲染模型数据,将模型里的数据以某种形式呈现给客户。
为了实现视图模型和具体实现技术的解耦,Spring 在 org.springframework.web.servlet 包中定义了一个高度抽象的 View
接口
视图对象由视图解析器负责实例化。由于视图是无状态(即每个视图都有自己独立的线程)的,所以他们不会有线程安全的问题
常用的视图实现类
视图解析器
SpringMVC 为逻辑视图名的解析提供了不同的策略,可以在 Spring WEB 上下文中配置一种或多种解析策略,并指定他们之间的先后顺序。每一种映射策略对应一个具体的视图解析器实现类。
视图解析器的作用比较单一:将逻辑视图解析为一个具体的视图对象。
所有的视图解析器都必须实现 ViewResolver 接口:
常用的视图解析器实现类
程序员可以选择一种视图解析器或混用多种视图解析器
每个视图解析器都实现了 Ordered 接口并开放出一个 order 属性,可以通过 order 属性指定解析器的优先顺序,order 越小优先级越高。
SpringMVC 会按视图解析器顺序的优先顺序对逻辑视图名进行解析,直到解析成功并返回视图对象,否则将抛出 ServletException 异常
InternalResourceViewResolver
JSP 是最常见的视图技术,可以使用
InternalResourceViewResolver 作为视图解析器:
若项目中使用了 JSTL,则 SpringMVC 会自动把视图由 InternalResourceView 转为 JstlView
若使用 JSTL 的 fmt 标签则需要在 SpringMVC 的配置文件中配置国际化资源文件
若希望直接响应通过 SpringMVC 渲染的页面,可以使用 mvc:view-controller 标签实现
Excel 视图
若希望使用 Excel 展示数据列表,仅需要扩展
SpringMVC 提供的 AbstractExcelView 或
AbstractJExcel View 即可。实现 buildExcelDocument()
方法,在方法中使用模型数据对象构建 Excel 文档就可以了。
AbstractExcelView 基于 POI API,而AbstractJExcelView 是基于 JExcelAPI 的。
视图对象需要配置 IOC 容器中的一个 Bean,使用
BeanNameViewResolver 作为视图解析器即可
若希望直接在浏览器中直接下载 Excel 文档,则可以设置响应头 Content-Disposition 的值为 attachment;filename=xxx.xls
关于重定向
一般情况下,控制器方法返回字符串类型的值会被当成逻
辑视图名处理
如果返回的字符串中带 forward: 或 redirect: 前缀
时,SpringMVC 会对他们进行特殊处理:将 forward: 和
redirect: 当成指示符,其后的字符串作为 URL 来处理
– redirect:success.jsp:会完成一个到 success.jsp 的重定向的操作
– forward:success.jsp:会完成一个到 success.jsp 的转发操作
处理静态资源
优雅的 REST 风格的资源URL 不希望带 .html 或 .do 等后缀
若将 DispatcherServlet 请求映射配置为 /,则 Spring MVC 将捕获
WEB 容器的所有请求,包括静态资源的请求, SpringMVC 会将他们当成一个普通请求处理,因找不到对应处理器将导致错误。
可以在 SpringMVC 的配置文件中配置 mvc:default-servlet-handler/ 的方式解决静态资源的问题:
– mvc:default-servlet-handler/ 将在 SpringMVC 上下文中定义一个
DefaultServletHttpRequestHandler,它会对进入 DispatcherServlet 的
请求进行筛查,如果发现是没有经过映射的请求,就将该请求交由 WEB 应用服务器默认的 Servlet 处理,如果不是静态资源的请求,才由
DispatcherServlet 继续处理
– 一般 WEB 应用服务器默认的 Servlet 的名称都是 default。若所使用的 WEB 服务器的默认 Servlet 名称不是 default,则需要通过 default-servlet-name 属性显式指定