SpringMVC常⽤注解,返回⽅式,路径匹配形式
1、@RequestMapping注解⼩结:
@RequestMapping 可以标注在类定义处,将 Controller 和特定请求关联起来;还可以标注在⽅法签名处,以便进⼀步对请求进⾏分流。配套的属性有:
value 需要跳转的地址
method 基于RestFul的跳转参数,有 post put delete等
params 符合某个参数的时候才调⽤该⽅法
Headers 符合头信息的时候才调⽤
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";
}
3、springmvc常⽤注解含义:
1)@ResponseBody 在⽅法上标注后,返回String对象的结果为response内容体(response⼀个json/xml对象),不标注的话作为dispatcher url使⽤(跳转到视图)
2)Model对象:model对象有addAttribute(a, b)⽅法,作⽤域在request上, 相当于request.setAttribute(),在前端可以通过Attribute()或者EL表达式获取到相应的值。例如:
@RequestMapping(value = "/loginSubmit")
public String loginSubmit(String loginName,String passwd,HttpServletRequest request,Model model) {
try {
User user = loginService.loginSubmit(loginName,passwd);
//request.setAttribute("user", user);
model.addAttribute("user", user);
return "index";
} catch (Exception e) {
<(e.getMessage());
return "error/error";
}
}
在jsp中可以通过JSTL表达式获取:${user.name}
4)@SessionAttributes:将结果放⼊session内
4、springmvc返回类型:
1 使⽤⽆返回类型的⽅法跳转,或者返回ModelMap类型的⽅法 进⾏跳转的话,则返回的视图要根据请求⽅法对应的url名(或者⽅法名)来
定,springmvc会通过视图解析器进⾏以prefix(前缀)+url名(⽅法名)+suffix(后缀)组成的页⾯⽂件名称.
2 使⽤⼀个返回的字符串(String)⽅法作为跳转,好处就是在return的时候可以⾃⼰指定返回的名字,JSP组成是prefix(前缀)+返回的字符串+suffix(后缀)
3 返回⼀个ModelAndView类型,可以通过ModelAndView构造⽅法可以指定返回的页⾯名称,也可以通过setViewName()⽅法跳转到指定的页⾯。同时,使⽤addObject()设置需要返回的模型数据值,这样在视图中就可以通过Attribute()或JSTL表达式获得相应的模型数据值。
el表达式获取session中的值实例:
1、使⽤void⽅法,此时逻辑视图名由请求处理⽅法对应的 URL (⽅法名)确定,这时的视图为welcome
@RequestMapping("/welcome")
public void welcomeHandler() {
<span > </span>。。。
}
2、返回ModelMap 和返回类型为 void ⼀样,逻辑视图名取决于对应请求的 URL(⽅法名),这时视图为vets。
返回的 ModelMap 将被作为请求对应的模型对象,可以在 JSP 视图页⾯中访问到
@RequestMapping("/vets")
public ModelMap vetsHandler() {
return new ModelMap(Vets());
}
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}
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论