首先看一下spring的配置文件,以下web
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:context="http://www.springframework.org/schema/context" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation=" http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.0.xsd"> <context:component-scan base-package="com.lei.demo.controller" /> <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"> <property name="prefix"> <value>/WEB-INF/user/</value> </property> <property name="suffix"> <value>.jsp</value> </property> </bean> </beans>
第一种,返回类型为String,Controller中的方法以下spring
@RequestMapping(value="welcome",method=RequestMethod.GET) public String printMessage(ModelMap model) { model.addAttribute("message", "返回类型String"); return "users"; }
根据spring配置文件和以上controller,访问“/welcome”时,对应的返回页面为“/WEB-INF/user/users.jsp”app
第二种,返回类型为ModelAndView,Controller中的方法以下jsp
@RequestMapping("/welcome") public ModelAndView printMessage (){ ModelAndView mv = new ModelAndView(); mv.addObject("message", "返回类型ModelAndView "); mv.setViewName("users"); return mv; }
两种方法返回的页面相同,不一样的是第二种方法将model和view整合成ModelAndView实例,方法中不须要再加入model参数。函数
@RequestMapping能够是类级别和方法级别。url
@Controller @RequestMapping("/user") public class UserController { //访问此方法的url为“/user/manager”,url前要加入类级别的路径/user @RequestMapping(value="/manager",method=RequestMethod.GET) public ModelAndView printMessage(){ ModelAndView mv = new ModelAndView(); mv.addObject("message", "MVC"); mv.setViewName("users"); return mv; } //访问此方法的url为“/user/hello”,url前要加入类级别的路径/user @RequestMapping(value="/hello",method=RequestMethod.GET) public ModelAndView hello(){ ModelAndView mv = new ModelAndView(); mv.addObject("message", "hello"); mv.setViewName("users"); return mv; } }
@Controller public class UserController { //没有类级别的@RequestMapping,访问此方法的url为“/manager” @RequestMapping(value="/manager",method=RequestMethod.GET) public ModelAndView printMessage(){ ModelAndView mv = new ModelAndView(); mv.addObject("message", "MVC"); mv.setViewName("users"); return mv; } //没有类级别的@RequestMapping,访问此方法的url为“/hello” @RequestMapping(value="/hello",method=RequestMethod.GET) public ModelAndView hello(){ ModelAndView mv = new ModelAndView(); mv.addObject("message", "hello"); mv.setViewName("users"); return mv; } }
@RequestMapping(value={"/hello","/foo"}) public ModelAndView hello(){ ModelAndView mv = new ModelAndView(); mv.addObject("message", "hello"); mv.setViewName("users"); return mv; }
以上“/hello”和“/foo”映射到同一个函数处理。code
@RequestMapping有以下几个属性:value、method、params、headerscomponent
这几个属性用法以下xml
经过value属性,表达主要的映射,在Servlet环境中,映射路径(如,/myPath.do),也支持Any风格的(如,/myPath/*.do)。在方法级别中的相对路径须要类级别的主路径支持。blog
@RequestMapping("/user")等同于@RequestMapping(value="/user")
经过HTTP请求的method来缩小主映射的范围。GET, POST, HEAD, OPTIONS, PUT, DELETE, TRACE。支持定义在类级别或方法级别。
格式为“paramname=paramvalue” 或 “paramname!=paramvalue”。不带参数则表示paramvalue能够为任意值。
例如,params = {"param1=1","param2!=2","param3"},表示对应的url必须包括param1,param2,param3三个参数,其中param1的值必须为1,param2的值不能为2,param3的值能够为任意值。
headers用来限定对应的reqeust请求的headers中必须包括的内容,例如
headers={"Connection=keep-alive"}, 表示请求头中的connection的值必须为keep-alive。