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>
相关推荐
吾日三省吾码2 小时前
JVM 性能调优
java
y先森3 小时前
CSS3中的伸缩盒模型(弹性盒子、弹性布局)之伸缩容器、伸缩项目、主轴方向、主轴换行方式、复合属性flex-flow
前端·css·css3
前端Hardy3 小时前
纯HTML&CSS实现3D旋转地球
前端·javascript·css·3d·html
susu10830189113 小时前
vue3中父div设置display flex,2个子div重叠
前端·javascript·vue.js
弗拉唐3 小时前
springBoot,mp,ssm整合案例
java·spring boot·mybatis
sun0077004 小时前
ubuntu dpkg 删除安装包
运维·服务器·ubuntu
oi774 小时前
使用itextpdf进行pdf模版填充中文文本时部分字不显示问题
java·服务器
IT女孩儿4 小时前
CSS查缺补漏(补充上一条)
前端·css