转自:http://blog.csdn.net/zb0567/article/details/7921155#comments
spring mvc处理方法支持如下的返回方式:ModelAndView, Model, ModelMap, Map,View, String, void。下面将对具体的一一进行说明:
ModelAndView
- @RequestMapping("/show1")
- public ModelAndView show1(HttpServletRequest request,
- HttpServletResponse response) throws Exception {
- ModelAndView mav = new ModelAndView("/demo2/show");
- mav.addObject("account", "account -1");
- return mav;
- }
通过ModelAndView构造方法可以指定返回的页面名称,也可以通过setViewName()方法跳转到指定的页面 ,
使用addObject()设置需要返回的值,addObject()有几个不同参数的方法,可以默认和指定返回对象的名字。
调用addObject()方法将值设置到一个名为ModelMap的类属性,ModelMap是LinkedHashMap的子类,
具体请看类。
Model 是一个接口, 其实现类为ExtendedModelMap,继承了ModelMap类。
Map
- @RequestMapping("/demo2/show")
- public Map<String, String> getMap() {
- Map<String, String> map = new HashMap<String, String>();
- map.put("key1", "value-1");
- map.put("key2", "value-2");
- return map;
- }
在jsp页面中可直通过${key1}获得到值, map.put()相当于request.setAttribute方法。
写例子时发现,key值包括 - . 时会有问题.
View 可以返回pdf excel等,暂时没详细了解。
String 指定返回的视图页面名称,结合设置的返回地址路径加上页面名称后缀即可访问到。
注意:如果方法声明了注解@ResponseBody ,则会直接将返回值输出到页面。
例如:
- @RequestMapping(value = "/something", method = RequestMethod.GET)
- @ResponseBody
- public String helloWorld() {
- return "Hello World";
- }
上面的结果会将文本"Hello World "直接写到http响应流。
- @RequestMapping("/welcome")
- public String welcomeHandler() {
- return "center";
- }
对应的逻辑视图名为“center”,URL= prefix前缀+视图名称 +suffix后缀组成。
void 如果返回值为空,则响应的视图页面对应为访问地址
- @RequestMapping("/welcome")
- public void welcomeHandler() {}
此例对应的逻辑视图名为"welcome"。
小结:
1.使用 String 作为请求处理方法的返回值类型是比较通用的方法,这样返回的逻辑视图名不会和请求 URL 绑定,具有很大的灵活性,而模型数据又可以通过 ModelMap 控制。
2.使用void,map,Model 时,返回对应的逻辑视图名称真实url为:prefix前缀+视图名称 +suffix后缀组成。
3.使用String,ModelAndView返回视图名称可以不受请求的url绑定,ModelAndView可以设置返回的视图名称。
Model model,HttpServletRequest request, ModelMap map声明变量
request.getSession().setAttribute("test", "haiwei2Session");
request.setAttribute("test", "haiwei1request");
map.addAttribute("test", "haiweiModelMap");
model.addAttribute("test", "haiweiModel");
我通过${test}这个方式取值,优先取Model和ModelMap的,Model和ModelMap是同一个东西,谁最后赋值的就取谁的,然后是request,最后是从session中获取。
SpringMVC+ajax返回JSON串
转自(文章很好,最好看原文):http://blog.csdn.net/zdp072/article/details/18187033
一、引言
本文使用springMVC和ajax做的一个小小的demo,实现将JSON对象返回到页面,没有什么技术含量,纯粹是因为最近项目中引入了springMVC框架,作为学习之用,不喜勿喷,欢迎拍砖。
二、入门例子
①. 建立工程,并导入相应spring jar包和解析json的包fastjson。
②. 在web.xml文件中配置Spring的核心类DispatcherServlet
③. 配置Spring的核心配置文件spring-servlet.xml
④. 编写实体类Person
- public class Person {
- private String name;
- private Integer age;
- public String getName() {
- return name;
- }
- public void setName(String name) {
- this.name = name;
- }
- public Integer getAge() {
- return age;
- }
- public void setAge(Integer age) {
- this.age = age;
- }
- public String toString() {
- return "[name: " + name + ", age: " + age + "]";
- }
- }
public class Person {
private String name;
private Integer age;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Integer getAge() {
return age;
}
public void setAge(Integer age) {
this.age = age;
}
public String toString() {
return "[name: " + name + ", age: " + age + "]";
}
}
⑤. 编写控制器类PersonControll
- @Controller
- public class PersonControll {
- @RequestMapping("toAjax.do")
- public String toAjax() {
- return "ajax";
- }
- @RequestMapping(value = "ajax.do", method = RequestMethod.GET)
- public void ajax(@ModelAttribute Person person,PrintWriter printWriter) {
- System.out.println(person);
- String jsonString = JSON.toJSONString(person, SerializerFeature.PrettyFormat);
- printWriter.write(jsonString);
- printWriter.flush();
- printWriter.close();
- }
- }
@Controller
public class PersonControll {
@RequestMapping("toAjax.do")
public String toAjax() {
return "ajax";
}
@RequestMapping(value = "ajax.do", method = RequestMethod.GET)
public void ajax(@ModelAttribute Person person,PrintWriter printWriter) {
System.out.println(person);
String jsonString = JSON.toJSONString(person, SerializerFeature.PrettyFormat);
printWriter.write(jsonString);
printWriter.flush();
printWriter.close();
}
}
⑥. 编写访问页面ajax.jsp
- <%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding="utf-8"%>
- <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
- <html>
- <head>
- <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
- <title>ajax for springMVC</title>
- <script type="text/javascript" src="js/jquery-1.6.2.min.js"></script>
- <script type="text/javascript">
- $(function() {
- $("#click").click(function() {
- $.ajax( {
- type : "GET",
- url : "ajax.do",
- data : "name=zhangsan&age=25",
- dataType: "json",
- success : function(msg) {
- alert(msg.name + "," + msg.age);
- }
- });
- });
- });
- </script>
- </head>
- <body>
- <input id="click" type="button" value="click to show person" />
- </body>
- </html>
<%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding="utf-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>ajax for springMVC</title>
<script type="text/javascript" src="js/jquery-1.6.2.min.js"></script>
<script type="text/javascript">
$(function() {
$("#click").click(function() {
$.ajax( {
type : "GET",
url : "ajax.do",
data : "name=zhangsan&age=25",
dataType: "json",
success : function(msg) {
alert(msg.name + "," + msg.age);
}
});
});
});
</script>
</head>
<body>
<input id="click" type="button" value="click to show person" />
</body>
</html>
⑦. 访问url: http://localhost:8080/springMVC/toAjax.do
⑧. 源码下载 http://download.csdn.net/detail/zdp072/6840545