1、@RequestMapping注解小结:
@RequestMapping 可以标注在类定义处,将 Controller 和特定请求关联起来;还可以标注在方法签名处,以便进一步对请求进行分流。配套的属性有:
value 需要跳转的地址
method 基于RestFul的跳转参数,有RequestMethod.get post put delete等
params 符合某个参数的时候才调用该方法
Headers 符合头信息的时候才调用
这样访问http://localhost:8080/××/login/login
就可访问到改方法里了。
2、绑定参数:
1)参数绑定:
@RequestMapping(value="/departments") public String findDepatment(@RequestParam("departmentId") String departmentId){ System.out.println("Find department with ID: " + departmentId); return "someResult"; }
形如这样的访问形式: /departments?departmentId=23就可以触发访问findDepatment方法了
2)REST风格的参数
@RequestMapping(value="/departments/{departmentId}") public String findDepatment(@PathVariable String departmentId){ System.out.println("Find department with ID: " + departmentId); return "someResult"; }
形如REST风格的地址访问,比如: /departments/23,其中用(@PathVariable接收rest风格的参数
3)REST风格的参数绑定形式之2
@RequestMapping(value="/departments/{departmentId}") public String findDepatmentAlternative(@PathVariable("departmentId") String someDepartmentId){ System.out.println("Find department with ID: " + someDepartmentId); return "someResult"; }
这个有点不同,就是接收形如/departments/23的URL访问,把23作为传入的departmetnId,,但是在实际的方法findDepatmentAlternative中,使用
@PathVariable("departmentId") String someDepartmentId,将其绑定为 someDepartmentId,所以这里someDepartmentId为23
4)url中同时绑定多个id
@RequestMapping(value="/departments/{departmentId}/employees/{employeeId}") public String findEmployee(@PathVariable String departmentId,@PathVariable String employeeId){ System.out.println("Find employee with ID: " + employeeId + " from department: " + departmentId); return "someResult"; }
5)支持正则表达式
@RequestMapping(value="/{textualPart:[a-z-]+}.{numericPart:[\\d]+}") public String regularExpression( @PathVariable String textualPart, @PathVariable String numericPart){ System.out.println("Textual part: " + textualPart + ", numeric part: " + numericPart); return "someResult"; }
注:上面的参数绑定,只是一些一些特殊的。要了解关于springmvc数据绑定,请看这篇文章:http://blog.csdn.net/liuxiao723846/article/details/43704403
3、springmvc常用注解含义:
1)@ResponseBody 在方法上标注后,返回String对象的结果为response内容体(response一个json/xml对象),不标注的话作为dispatcher
url使用(跳转到视图)
2)Model对象:model对象有addAttribute(a,
b)方法,作用域在request上, 相当于request.setAttribute(),在前端可以通过request.getAttribute()或者EL表达式获取到相应的值。例如:
@RequestMapping(value = "/loginSubmit") public String loginSubmit(String loginName,String passwd,HttpServletRequest request,Model model) { try { User user = loginService.loginSubmit(loginName,passwd); request.getSession().setAttribute(Constants.SESSION_USER, user); //request.setAttribute("user", user); model.addAttribute("user", user); return "index"; } catch (Exception e) { logger.error(e.getMessage()); return "error/error"; } }
在jsp中可以通过JSTL表达式获取:${user.name}
3)@ModelAttribute:详见 http://blog.csdn.net/liuxiao723846/article/details/43713749
4)@SessionAttributes:将结果放入session内
4、springmvc返回类型:
1 使用无返回类型的方法跳转,或者返回ModelMap类型的方法 进行跳转的话,则返回的视图要根据请求方法对应的url名(或者方法名)来定,springmvc会通过视图解析器进行以prefix(前缀)+url名(方法名)+suffix(后缀)组成的页面文件名称.
2 使用一个返回的字符串(String)方法作为跳转,好处就是在return的时候可以自己指定返回的名字,JSP组成是prefix(前缀)+返回的字符串+suffix(后缀)
3 返回一个ModelAndView类型,可以通过ModelAndView构造方法可以指定返回的页面名称,也可以通过setViewName()方法跳转到指定的页面。同时,使用addObject()设置需要返回的模型数据值,这样在视图中就可以通过reuqest.getAttribute()或JSTL表达式获得相应的模型数据值。
实例:
1、使用void方法,此时逻辑视图名由请求处理方法对应的 URL (方法名)确定,这时的视图为welcome
@RequestMapping("/welcome") public void welcomeHandler() { <span style="white-space:pre"> </span>。。。 }
2、返回ModelMap 和返回类型为 void 一样,逻辑视图名取决于对应请求的 URL(方法名),这时视图为vets。
返回的 ModelMap 将被作为请求对应的模型对象,可以在 JSP 视图页面中访问到
@RequestMapping("/vets") public ModelMap vetsHandler() { return new ModelMap(this.clinic.getVets()); }
3、返回string类型,这时视图为ownerForm。(注:这时不能有responseBody,否则就会转成json对象)
@RequestMapping(method = RequestMethod.GET) public String setupForm(@RequestParam("ownerId") int ownerId, ModelMap model) { Owner owner = this.clinic.loadOwner(ownerId); model.addAttribute(owner); return "ownerForm"; }
4、返回ModelAndView对象:返回到指定的视图/springmvc/common,同时可以在视图中获得message数据——通过JSTL,${message}
@RequestMapping("/springmvc/modelAndView") public ModelAndView modelAndView(){ ModelAndView mav = new ModelAndView(); mav.setViewName("/springmvc/common"); mav.addObject("message", "modelAndView 方法被调用"); return mav; }