springMVC-模型数据的处理

一、数据放入到request域当中

1、把获取的数据放入request域中, 方便在跳转页面去显示

html 复制代码
<a>添加主人信息</a>
<form action="vote/vote04" method="post" >
    主人id:<input type="text" name="id"><br>
    主人名:<input type="text" name="monsterName"><br>
    宠物名:<input type="text" name="pet.petName"><br>
    <input type="submit" value="提交" ><br>
java 复制代码
   @RequestMapping(value = "/vote04")
    public String vote04(Monster monster, HttpServletRequest request,
                         HttpServletResponse response){
        System.out.println("请求到vote04");
        request.setAttribute("monster", monster);
        request.setAttribute("address","湖州");
        return "voteOK";
    }
html 复制代码
<%@ page contentType="text/html;charset=UTF-8" language="java" isELIgnored="false" %>
<html>
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>获取参数成功

    地址:   ${address}<br>
    主人名字:${requestScope.monster.monsterName}<br>
    主人信息:${requestScope.monster}<br>
</body>
</html>

2、通过请求的方法参数Map<String,Object>, springMVC自动将map参数的内容放入reguest域

html 复制代码
<%--确保这里的name与bean的属性名一致,否则拿不到值--%>
<a>添加主人信息</a>
<form action="vote/vote05" method="post" >
    主人id:<input type="text" name="id"><br>
    主人名:<input type="text" name="monsterName"><br>
    宠物名:<input type="text" name="pet.petName"><br>
    <input type="submit" value="提交" ><br>
</form>
java 复制代码
   @RequestMapping(value = "/vote05")
    public String vote05(Monster monster, Map <String,Object> map){
        map.put("monster", monster);
        map.put("Address", "BEIJING");
        return "voteOK";
    }
html 复制代码
<%@ page contentType="text/html;charset=UTF-8" language="java" isELIgnored="false" %>
<html>
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>获取参数成功

    地址:   ${address}<br>
    主人名字:${requestScope.monster.monsterName}<br>
    主人信息:${requestScope.monster}<br>

3、通过返回一个ModelAndView对象实现request域数据

1>从本质看,请求响应的方法return"xx",好像是返回了一个字符串,其实本质都是返回了一个ModeIAndView对象,只是默认被封装起来的.

2>ModelAndView即可以包含model数据,也可以包含视图信息

3>ModelAndView对象的addObject方法可以添加 key-val数据,默认在request域中4>ModelAndView对象setView方法可以指定视图名称

html 复制代码
<%--确保这里的name与bean的属性名一致,否则拿不到值--%>
<a>添加主人信息</a>
<form action="vote/vote06" method="post" >
    主人id:<input type="text" name="id"><br>
    主人名:<input type="text" name="monsterName"><br>
    宠物名:<input type="text" name="pet.petName"><br>
    <input type="submit" value="提交" ><br>
</form>
java 复制代码
  @RequestMapping(value = "/vote06")
    public ModelAndView vote06(Monster monster){
        //创建一个modleANDView
        ModelAndView modelAndView = new ModelAndView();
        modelAndView.addObject("monster", monster);
        modelAndView.addObject("address", "杭州");
        modelAndView.setViewName("voteOK");
        return modelAndView;
    }
html 复制代码
<%@ page contentType="text/html;charset=UTF-8" language="java" isELIgnored="false" %>
<html>
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>获取参数成功

    地址:   ${address}<br>
    主人名字:${requestScope.monster.monsterName}<br>
    主人信息:${requestScope.monster}<br>
</body>

二、将数据放入到session域中

1、通过@SessionAttributes实现将数据放入session域

首先,在handler上写一个@SessionAttributes注解

java 复制代码
@SessionAttributes(value = "myMaster")
@RequestMapping(value = "/vote")
@Controller
public class VoteHandler {

只要有一个map的形参,调用了put方法,且key值与@SessionAttributes相同,就会被自动放入到session域中

java 复制代码
@RequestMapping(value = "/vote07")
    public String vote07(Map <String,Object> map,Monster monster){
       map.put("myMonster",monster);
       map.put("address","SHANGHAI");
        return "voteOK";
    }
html 复制代码
<%@ page contentType="text/html;charset=UTF-8" language="java" isELIgnored="false" %>
<html>
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>获取参数成功

    地址:   ${address}<br>
    主人名字:${requestScope.monster.monsterName}<br>
    主人信息:${requestScope.monster}<br>

    主人名字(session):${sessionScope.myMonter.monsterName}<br>
    主人信息(session):${sessionScope.myMonter}<br>

</body>
相关推荐
前端不太难20 分钟前
《Vue 项目路由 + Layout 的最佳实践》
前端·javascript·vue.js
LYFlied23 分钟前
【每日算法】 LeetCode 56. 合并区间
前端·算法·leetcode·面试·职场和发展
想学后端的前端工程师1 小时前
【Vue3组合式API实战指南:告别Options API的烦恼】
前端·javascript·vue.js
否子戈1 小时前
WebCut前端视频编辑UI框架一周开源进度
前端·音视频开发·ui kit
昔人'1 小时前
`corepack` 安装pnpm
前端·pnpm·node·corepack
萌萌哒草头将军1 小时前
pnpm + monorepo 才是 AI 协同开发的最佳方案!🚀🚀🚀
前端·react.js·ai编程
程序员佳佳2 小时前
2025年大模型终极横评:GPT-5.2、Banana Pro与DeepSeek V3.2实战硬核比拼(附统一接入方案)
服务器·数据库·人工智能·python·gpt·api
qq_12498707532 小时前
重庆三峡学院图书资料管理系统设计与实现(源码+论文+部署+安装)
java·spring boot·后端·mysql·spring·毕业设计
hboot2 小时前
💪别再迷茫!一份让你彻底掌控 TypeScript 类型系统的终极指南
前端·typescript
大学生资源网2 小时前
java毕业设计之“知语”花卉销售网站的设计与实现源码(源代码+文档)
java·mysql·毕业设计·源码·springboot