Spring MVC 模型和视图

内容概要

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 属性显式指定

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值