@Controller @RequestMapping("/pages")//①处理器的通用映射前缀,如果在类上使用@ RequestMapping 注解一般是用于窄化功能处理方法的映射的 public class TestController { //方法级别窄化,//②相对于①处的映射进行窄化 @RequestMapping(value="test", method=RequestMethod.POST)//请求URL到处理器功能处理方法的映射 public ModelAndView test(){ //1、收集参数 //2、绑定参数到命令对象 //3、调用业务对象 //4、选择下一个页面 ModelAndView mav = new ModelAndView(); //设置逻辑视图名,也可以直接设置页面路径 mav.setViewName("/pages/test.jsp"); //添加模型数据 可以是任意的POJO对象 mav.addObject("msg", "消息发送成功!"); return mav; //ModelMap model = new ModelMap(); //model.addAttribute("msg", "消息发送成功!"); //return new ModelAndView("("/pages/test.jsp",model); } }
通过ModelAndView构造方法可以指定返回的页面名称,也可以通过setViewName()方法跳转到指定的页面 ,
使用addObject()设置需要返回的值,addObject()有几个不同参数的方法,可以默认和指定返回对象的名字。
调用addObject()方法将值设置到一个名为ModelMap的类属性,ModelMap是LinkedHashMap的子类
String 指定返回的视图页面名称,结合设置的返回地址路径加上页面名称后缀即可访问到。
注意:如果方法声明了注解@ResponseBody ,则会直接将返回值输出到页面。
@RequestMapping() @ResponseBody public String helloWorld() { return "Hello World"; }
上面的结果会将文本"Hello World "直接写到http响应流。
@RequestMapping("/hello") public String world() { return "test"; }
对应的逻辑视图名为“test”,URL= prefix前缀+视图名称 +suffix后缀组成(需要配置视图解析)。
@RequestMapping("/test") public void hello() {}
void 如果返回值为空,则响应的视图页面对应为访问地址
此例对应的逻辑视图名为"test"。
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("test1", "hello1");
request.setAttribute("test2", "hello2");
map.addAttribute("test3", "hello3");
model.addAttribute("test4", "hello4");
我通过${test}这个方式取值,优先取Model和ModelMap的,Model和ModelMap是同一个东西,谁最后赋值的就取谁的,然后是request,最后是从session中获取