首页 > 其他分享 >5. 域对象共享数据

5. 域对象共享数据

时间:2023-06-20 12:44:15浏览次数:32  
标签:对象 public ModelAndView 共享 数据 Model

在SpringMVC中,域对象(也称为作用域对象)是一种可以在请求处理过程中共享数据的机制。SpringMVC提供了多种类型的域对象,包括request域、session域和application域。

通过在控制器方法中定义方法参数,SpringMVC可以自动将数据绑定到域对象中,从而在请求处理过程中实现数据共享。例如,在一个简单的控制器方法中,可以定义一个Model对象作为参数,将需要共享的数据放到Model对象中,然后返回一个逻辑视图名,这个视图可以使用Model对象中的数据。

@RequestMapping("/users/{id}")
public String getUserDetail(@PathVariable Integer id, Model model) {
    User user = userService.getUserById(id);
    model.addAttribute("user", user);
    return "userDetail";
}

在上述代码中,通过使用Model对象,控制器方法将User对象添加到model中,然后返回了一个逻辑视图名”userDetail”,这个视图将会使用model中的数据进行渲染。

接下来,在逻辑视图中可以使用EL表达式访问model中存储的数据,从而将数据进行展示。

<html>
    <head>
        <title>User Detail</title>
    </head>
    <body>
        <h1>User Detail</h1>
        <ul>
            <li>Name: ${user.name}</li>
            <li>Email: ${user.email}</li>
            <li>Address: ${user.address}</li>
        </ul>
    </body>
</html>

通过上述示例,可以看出在SpringMVC中,域对象是实现数据共享的一个非常重要的机制。不同类型的域对象可以在不同的范围内共享数据,例如,在request域中存储的数据仅在当前请求范围内共享,而在session域中存储的数据则可以在同一用户的多个请求中共享。

1. 使用ServletAPI向request域对象共享数据

@RequestMapping("/testServletAPI")
public String testServletAPI(HttpServletRequest request){
    request.setAttribute("testScope", "hello,servletAPI");
    return "success";
}

2. 使用ModelAndView向request域对象共享数据

向域对象共享数据:

通过ModelAndView​向请求域共享数据

  • 使用ModelAndView时 , 可以使用Model功能向请求域共享数据
  • 使用View功能设置逻辑视图 , 但是控制器方法一定要将ModelAndView作为方法返回值
@RequestMapping("/testModelAndView")
public ModelAndView testModelAndView(){
    /**
     * ModelAndView有Model和View的功能
     * Model主要用于向请求域共享数据
     * View主要用于设置视图,实现页面跳转
     */
    ModelAndView mav = new ModelAndView();
    //向请求域共享数据
    mav.addObject("testScope", "hello,ModelAndView");
    //设置视图,实现页面跳转
    mav.setViewName("success");
    return mav;
}

3. 使用Model向request域对象共享数据

@RequestMapping("/testModel")
public String testModel(Model model){
    model.addAttribute("testScope", "hello,Model");
    return "success";
}

4. 使用map向request域对象共享数据

@RequestMapping("/testMap")
public String testMap(Map<String, Object> map){
    map.put("testScope", "hello,Map");
    return "success";
}

5. 使用ModelMap向request域对象共享数据

@RequestMapping("/testModelMap")
public String testModelMap(ModelMap modelMap){
    modelMap.addAttribute("testScope", "hello,ModelMap");
    return "success";
}

6. Model、ModelMap、Map的关系

Model、ModelMap、Map类型的参数其实本质上都是 BindingAwareModelMap 类型的

public interface Model{}
public class ModelMap extends LinkedHashMap<String, Object> {}
public class ExtendedModelMap extends ModelMap implements Model {}
public class BindingAwareModelMap extends ExtendedModelMap {}

7. 向session域共享数据

@RequestMapping("/testSession")
public String testSession(HttpSession session){
    session.setAttribute("testSessionScope", "hello,session");
    return "success";
}

8. 向application域共享数据

@RequestMapping("/testApplication")
public String testApplication(HttpSession session){
    ServletContext application = session.getServletContext();
    application.setAttribute("testApplicationScope", "hello,application");
    return "success";
}

标签:对象,public,ModelAndView,共享,数据,Model
From: https://www.cnblogs.com/NorthPoet/p/17493334.html

相关文章

  • MATLAB dsp数据采集系统的Matlab GUI源代码作为参考非常不错 MATLAB是一种
    MATLABdsp数据采集系统的MatlabGUI源代码作为参考非常不错MATLAB是一种强大的数学计算和编程环境,广泛应用于科学、工程和技术领域。它提供了丰富的函数库和工具,用于数据分析、可视化、模拟和算法开发等任务。数据采集系统是一种用于收集、处理和存储数据的系统。它通常由传感器......
  • 【数据库原理、编程与性能】Integrity, View, Security
    文章目录1.IntegrityConstrains1.1Definition1.2实施机制1.3IntegrityConstraintsinCreateTableStatement1.3.1CreateTable1.3.2ColumnConstraints1.3.3TableConstraints.1.4AlterTableStatement1.5Trigger1.5.1CreateTriggerStatement1.5.2DropTrigger......
  • 【数据库原理、编程与性能】Indexing
    文章目录1.ConceptofIndexing1.1Index1.2CreateIndex1.3DB-Index分类1.4建立索引的原则:1.5DB-Index作用2.聚簇(Cluster/ClusterIndex)存取方法2.1概念2.2特点2.3弊端1.ConceptofIndexing1.1Index索引项=索引键+行指针索引是对数据库表中一列或多列的值进行排......
  • 【数据库原理、编程与性能】Updata Transaction
    文章目录1.TransactionHistories1.1并发(Concurrency)1.2并发操作会出现的DB问题1.3并发控制技术1.4封锁1.4.1锁类型1.4.2事务锁之间的相容矩阵1.5LockingProtocol1.5.1一级封锁协议1.5.2二级封锁协议1.5.3三级封锁协议2.NotationsTransactionHistories2.1Notation......
  • 【数据库原理、编程与性能】Basic SQL Query Language
    文章目录1.HistoryofSQL2.CapabilitiesofSQL2.1综合统一2.2高度非过程化2.3面向集合的操作方式2.4SQL以同一种语法结构提供两种使用方式2.5语言简捷,易学易用3.SQL语句3.1Create语句3.2Select语句3.3Subquery语句3.3.1定义3.3.2Conception(概念)3.3.3predicate(谓词......
  • 【计算机网络教程】数据链路层
    数据链路层知识点思维导图汇总如下:......
  • 【数据库原理、编程与性能】Programming to access a Database
    文章目录1.IntroductiontoEmbeddedSQLinC1.1Declaresection1.2Connect/Disconnect1.2.1Connect1.2.2Disconnect1.3Commit/Rollback1.4Whenever1.5一个实例:1.6HostVariable1.6.1Definition1.6.2说明1.6.3用法1.6.4实例1.6.5IndicatorVar2.CommonEmbedded......
  • JavaScript学习 -- 对象的属性描述对象
    一、声明一个对象let对象={name:"公众号:编程有你",pwd:123456};二、输出对象属性的描述//console.log(Object.getOwnPropertyDescriptors(对象))获取多有属性console.log(Object.getOwnPropertyDescriptor(对象,'name'))获取指定的属性三、运行结果:writable:true, ......
  • Mysql - 统计数据
    QA统计数据是做什么的?为了解释器在计算代价时,选择最优的方案.这个值如果与实际值差距过大,会导致执行顺序的变更.统计数据有哪些?对表的统计数据-mysql.innodb_table_stats对表索引的统计数据-mysql.innodb_index_stats统计数据存在哪?有两种方式,一种存在磁盘,一种存在......
  • python序列数据拆包
    元素的序列数据都可以进行数据拆解,如下#元组data_tuple=(1,2,3)a,b,c=data_tupleprint(a)#列表data_list=[11,22,33]a2,b2,c2=data_listprint(a2)#字典data_dic={'name':'zhangsan','age':'20'}print(data_dic["name"......