spring mvc(4)处理模型数据
处理模型数据
注:下面的代码均来自上一篇的注解代码之后的测试代码!!
ModelAndView
TestRequestMapping.java
@RequestMapping("/testModelAndView")
public ModelAndView testModelAndView(){ String viewName="success";
ModelAndView andView = new ModelAndView(viewName);
andView.addObject("time", new Date());
return andView;
}
index.jsp
<a href="springmvc/testModelAndView">testModelAndView</a>
success.jsp;
time:${requestScope.time}
总结:SpringMVC会把ModelAndView的model中数据放入到request域对象中
Map 及 Model
Spring MVC 在内部使用了一个org.springframework.ui.Model 接口存储模型数据
目标方法可以添加Map类型(实际上是Model或者ModelMap类型)的参数
TestRequestMapping.java
@RequestMapping("/testMap")
public String testMap(Map<String, Object> map){
map.put("name", "MrChengs"); return "success";
}
indexjsp
<a href="springmvc/testMap">testMap</a>
success.jsp
name:${requestScope.name}
@SessionAttributes
只能放在类的上面
TestRequestMapping.java
@SessionAttributes(value="user")
@Controller
@RequestMapping("/springmvc")
public class TestRequestMapping {
@RequestMapping("/testSessionAttributes")
public String testSessionAttributes(Map<String,Object> map){
User user = new User("MrChangs", "", "1287@qq.com");
map.put("user", user); return "success";
}
}
index.jsp
<a href="springmvc/testSessionAttributes">testSessionAttributes</a>
success.jsp
user requestScope:${requestScope.user}
<br>
<br>
user sessionScope:${sessionScope.user}
@ModelAttribute
<!--
模拟修改操作
1.原始数据:id=1,name=MrChengs,pw=1234,email=MrChengs@qq.com
2.密码不能修改
3.表单回显,模拟操作直接在表单填写对应的额属性值
-->
<form action="springmvc/ModelAttribute" method="post">
<input type="hidden" name="id" value="1">
<br>
name:<input type="text" name="username" value="MrChengs">
<br>
email:<input type="text" name="email" value="MrChengs@qq.com">
<br>
<input type="submit" value="submit">
</form>
//标记的方法会在每个目标方法执行之前被调用 //1.由@ModelAttribute标记的方法,会把每个目标之前被springmvc调用
//2.@MOdelAttribute注解也可以来修饰目标方法pojo类型的入参,其value属性值如下作用
//2.1)springmvc会使用value属性值在implicitModel中查找对应的对象,若存在直接传入到目标方法的入参中
//2.2)springmvc会把value为key,pojo类型对象为value,存到request中 @ModelAttribute
public void getUser(@RequestParam(value="id",required=false) Integer id,
Map<String,Object> map){
if(id != null){
User user = new User(1, "MrChengs", "1234", "MrChengs@qq.com");
System.out.println("得到一个参数"); //注意:这里的key为users,如果改为users等其他字符,等不到结果,程序可以正常的执行
//解决方法在下面的代码中
map.put("users", user);
}
} @RequestMapping("/ModelAttribute")
public String testModelAttribute(@ModelAttribute("users")User user){
System.out.println("update:" + user);
return "success";
}
user:${requestScope.users}
如果不添加@ModelAttribut,在测试中代码的值为null
@SessionAttributes(value="user")
@Controller
@RequestMapping("/springmvc")
public class TestRequestMapping {
@RequestMapping("/ModelAttribute")
public String testModelAttribute(User user){
System.out.println("update:" + user);
return "success";
}
}
public String testModelAttribute(@ModelAttribute("acbc")User user){
十月 16, 2018 4:38:06 下午 org.apache.catalina.core.StandardWrapperValve invoke
严重: Servlet.service() for servlet [springDispatcherServlet] in context with path [/Spring_MVC_01] threw exception [Session attribute 'user' required - not found in session] with root cause
org.springframework.web.HttpSessionRequiredException: Session attribute 'user' required - not found in session
at org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter$ServletHandlerMethodInvoker.raiseSessionRequiredException(AnnotationMethodHandlerAdapter.java:791)
@ModelAttribute
由@SessionAttributes引发的异常
org.springframework.web.HttpSessionRequiredExcept:
Session attribute 'user' required - not found in session
如何避免@SessionAttributes引发的异常
spring mvc(4)处理模型数据的更多相关文章
- Spring MVC 之传递模型数据到视图中
类似于 JSP-Servlet 中的 req.setAttribute . req.getSession().setAttribute ... --> 最后在 JSP 用 EL 表达式取得这些数 ...
- Spring MVC中的模型数据处理
一.综述 Spring MVC 提供了以下途径来输出模型数据: 1.ModelAndView 当处理方法返回值类型为 ModelAndView时, 方法体即可通过该对象添加模型数据到请求域. 2.Ma ...
- Spring MVC系列之模型绑定(SpringBoot)(七)
前言 上一节我们在SpringBoot中启用了Spring MVC最终输出了HelloWorld,本节我们来讲讲Spring MVC中的模型绑定,这个名称来源于.NET或.NET Core,不知是否恰 ...
- spring mvc 的jpa JpaRepository数据层 访问方式汇总
本文转载至:http://perfy315.iteye.com/blog/1460226 AppleFramework在数据访问控制层采用了Spring Data作为这一层的解决方案,下面就对Spri ...
- spring mvc返回json字符串数据,只需要返回一个java bean对象就行,只要这个java bean 对象实现了序列化serializeable
1.spring mvc返回json数据,只需要返回一个java bean对象就行,只要这个java bean 对象实现了序列化serializeable 2. @RequestMapping(val ...
- Spring MVC基础知识整理➣数据校验与格式化
概述 将view中Form的数据提交到后台之后,后台如何验证数据的有效性?在这里Spring MVC提供了相应的Hibernate类包(hibernate-validator-4.3.1.Final. ...
- Spring mvc,jQuery和JSON数据交互
一.实验环境的搭建 1.Spring mvc jar. 导入spring mvc运行所需jar包.导入如下(有多余) 2.json的支持jar 3.加入jQuery. 选用jquery-3.0.0.m ...
- spring mvc 返回xml格式数据
1.问题 : 因为业务需要,需要发送xml格式的数据,使用spring mvc 自己解析,就不用费心去自己搞这些东西. 2.解决: 新建一个实体类,直接在实体类中添加注解即可,如下: @XmlRoot ...
- 1.4(Spring MVC学习笔记)JSON数据交互与RESTful支持
一.JSON数据交互 1.1JSON简介 JSON(JavaScript Object Notation)是一种数据交换格式. 1.2JSON对象结构 {}代表一个对象,{}中写入数据信息,通常为ke ...
随机推荐
- php操作Excel
php操作Excel 1.new PHPExcel对象$objPHPExcel = new PHPExcel(); 2表的初始化设置$objPHPExcel->getProperties()-& ...
- Silverlight & Blend动画设计系列十一:沿路径动画(Animation Along a Path)
Silverlight 提供一个好的动画基础,但缺少一种方便的方法沿任意几何路径对象进行动画处理.在Windows Presentation Foundation中提供了动画处理类DoubleAnim ...
- css三栏布局方案整理
日常开发中,经常会用到css三栏布局,现将工作中常用的css 三栏布局整理如下: 什么是三栏布局: 三栏布局,顾名思义就是两边固定,中间自适应. 一. float布局 <!DOCTYPE htm ...
- spring-boot-starter-data-elasticsearch实现es的增删查改
首先,必须吐槽一下,springboot这个elasticsearch包对于elasticsearch的支持十分不友好,目前只支持很低版本的elasticsearch,如果有哪位大牛知道如何兼容更高版 ...
- java四大特性详解
Java的四大基础特性一.抽象 父类为子类提供一些属性和行为,子类根据业务需求实现具体的行为. 抽象类使用abstract进行修饰,子类要实现所有的父类抽象方法否则子类也是抽象类.二.封装 把对象的属 ...
- FFmpeg的tutorial 学习
一.前言: 这是一个学习 FFmpeg 的 tutorial 系列. 这个是一个对初学者比较友好的FFmpeg学习教程,作者一步步引导我们实现了一个音视频同步的播放器. 参考链接: 原文地址: htt ...
- Synchronized的原理及自旋锁,偏向锁,轻量级锁,重量级锁的区别(摘抄和理解)
1. 自旋锁的优缺点: 自旋锁 自旋锁原理非常简单,如果持有锁的线程能在很短时间内释放锁资源,那么那些等待竞争锁的线程就不需要做内核态和用户态之间的切换进入阻塞挂起状态,它们只需要等一等(自旋),等持 ...
- Java泛型拾遗
先上百度百科的解释 泛型是Java SE 1.5的新特性,泛型的本质是参数化类型,也就是说所操作的数据类型被指定为一个参数.这种参数类型可以用在类.接口和方法的创建中,分别称为泛型类.泛型接口.泛型方 ...
- jsp实现html页面静态化
一.实现原因 1.网站访问量过大,导致服务器压力加大以及数据库数据交换频繁.生成静态页面提供访问以缓解压力. 2.静态页面是动态页面的备份,若动态页面出现异常,静态页面可以暂时替代. 二.使用场合 ...
- mysql通过一张表更新另一张表
在mysql中,通过一张表的列修改另一张关联表中的内容: 1: 修改1列 update student s, city c set s.city_name = c.name where s.city ...