使用ModelAndView处理模型数据
1.SpringMVCTest.java控制器
package lxf.springmvc.handlers;
import java.util.Date;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.springframework.stereotype.Controller;
import org.springframework.web.servlet.ModelAndView;
import lxf.springmvc.entity.User;
/**
* 测试spring-mvc
* @author lxf
*
*/
@RequestMapping("springmvc")
@Controller
public class SpringMVCTest {
public static final String SUCCESS = "success";
/**
* 目标方法返回值是ModelAndView类型
* 其中包含视图和模型信息
* SpringMVC会把ModelAndView的model中的数据放到request域对象中
*/
@RequestMapping("/testModelAndView")
public ModelAndView testModelAndView()
{
String viewName = SUCCESS;
ModelAndView modelAndView = new ModelAndView(viewName);
//添加模型数据到ModelAndView中
modelAndView.addObject("time", new Date());
return modelAndView;
}
}
2.success.jsp内容
<h4>Success Page!</h4>
time:${requestScope.time}
3.访问测试:
http://localhost:8081/spring-mvc-helloworld/springmvc/testModelAndView
4.浏览器输出:
Success Page!
time:Sun Aug 06 17:56:12 CST 2017
使用Map及Model类型处理模型数据
1.SpringMVCTest控制器:
public static final String SUCCESS = "success";
/**
* 目标方法可以添加Map类型(实际上也可以是Model类型或ModelMap类型)的参数
* @param map
*/
@RequestMapping("testMap")
public String testMap(Map<String,Object>map)
{
System.out.println(map.getClass().getName());
map.put("names", Arrays.asList("Tom","Jerry","php"));
System.out.println("testMap");
return SUCCESS;
}
2.success.jsp页面
<h4>Success Page!</h4>
names:${requestScope.names}
3.访问测试:
http://localhost:8081/spring-mvc-helloworld/springmvc/testMap
4.浏览器输出:
names:[Tom, Jerry, php]
使用@SessionAttributes注解(该注解只能放在类的上边)
1.SpringMVCTest控制器
/*
* 使用@SessionAttributes注解将模型中的数据放在session作用域中
* 可以存指定字符串,也可以存指定类型
*/
@SessionAttributes(value={"user"},types={String.class})
@RequestMapping("springmvc")
@Controller
public class SpringMVCTest {
public static final String SUCCESS = "success";
/**
* 使用@SessionAttributes注解将模型中的数据放在session作用域中
* @param map
* @return
*/
@RequestMapping("/testSessionAttributes")
public String testSessionAttributes(Map<String,Object>map)
{
User user = new User("Liangxifeng","20");
//将user对象放到request请求域和Session域中,要保证@SessionAttributes(value={"user"},中value="user"
map.put("user", user);
//想request域和session域中存放key="lang"的字符串
map.put("lang", "java");
return SUCCESS;
}
}
2.success.jsp中打印存储在session域中的数据
request user:${requestScope.user}<br>
session user:${sessionScope.user}<br>
request lang:${requestScope.lang}<br>
session lang:${sessionScope.lang}
3.请求测试:
http://localhost:8081/spring-mvc-helloworld/springmvc/testSessionAttributes
输出:
request user:User [username=Liangxifeng, password=20, address=null]
session user:User [username=Liangxifeng, password=20, address=null]
request lang:java
session lang:java
@ModelAttribute注解的使用
我们通常将表单属性数据,传递给后台对应的实例,如果不做特殊设置的话,控制器是按着表单属性个数和实体类属性映射,比如:表单中属性为:
<!--
模拟修改操作
1.原始数据为:id=1 username="Tom" password="123456"
2.密码不能修改
3.表单回显,模拟操作直接在表单编写对应的属性值
-->
<form action="springmvc/testModelAttribute" method="post">
<input type="hidden" name="id" value="1">
username:<input type="text" name="username" value="Tom"/><br>
<input type="submit" value="提交" />
</form>
以上这个表单提交给给对应控制器方法
/**
* 测试ModelAttribute注解,可以在表单提交之前,对对应的实体属性先赋值
* @param user
* @return
*/
@RequestMapping("/testModelAttribute")
public String testModelAttribute(User user)
{
System.out.println("修改:" + user);
return SUCCESS;
}
提交表单后,java控制台输出为:
修改:User [username=Tom12121, password=null, address=null]
从上面我们可以看到表单并没有传递过来password属性,那么我们想通过该对象修改数据库,password不允许修改,此时的password=null,就不符合罗辑了,所以我们要在表单提交过来之前对User对象先赋值(数据来源可以是数据库),使用 @ModelAttribute
注解实现
/**
* 用@ModelAttribute注解标记的方法,会在每个目标方法执行执之前被SpringMVC调用
* @param id
* @param map
*/
@ModelAttribute
public void getUser(@RequestParam(value="id",required=false) Integer id,
Map<String,Object>map){
if(id!=null){
//模拟从数据库中获取对象
User user = new User(1, "Tom", "123456", null);
System.out.println("从数据中获取的对象是User = " + user);
map.put("user", user);
}
}
/**
* 测试ModelAttribute注解,可以在表单提交之前,对对应的实体属性先赋值
* @param user
* @return
*/
@RequestMapping("/testModelAttribute")
public String testModelAttribute(User user)
{
System.out.println("修改:" + user);
return SUCCESS;
}
表单提交后控制台输出:
从数据中获取的对象是User = User [username=Tom, password=123456, address=null]
修改:User [username=Tom12121, password=123456, address=null]