SpringMvc进阶
- SpringMVC引言
- 一、常用注解
- 二、参数传递
- 三、返回值
SpringMVC引言
在Web应用程序开发中,Spring MVC是一种常用的框架,它基于MVC(Model-View-Controller)模式,提供了一种结构化的方式来构建可维护和可扩展的应用程序。本文将介绍Spring MVC框架的基础知识和常用注解,以及参数传递、返回值处理和页面跳转等相关内容。
一、常用注解
1.1. @RequestMapping
@RequestMapping注解用于将HTTP请求映射到控制器方法上,通过指定URL路径和请求的方法类型来定义请求的处理。这是一个非常常用的注解,它可以灵活地匹配多种URL路径和请求方法,为控制器方法提供请求映射规则。
@RequestMapping("/hello1")
public String index(String bname,Integer bid ){
// System.out.println("hello springMvc..");
log.info("简单类型参数:bname:{},bid{}",bname,bid);
return "index";
}
1.2. @RequestParam
@RequestParam注解用于获取请求参数的值,可以指定参数名和默认值。它可以用于获取基本类型和包装类的参数,并支持参数的必填和可选设置。通过@RequestParam注解,我们可以方便地获取和处理请求中的参数数据。
@RequestMapping("/hello3")
public String hello3(@RequestParam String bname,@RequestParam(required = false) Integer bid){
// System.out.println("hello springMvc..");
log.info("@requestParam:bname:{},bid{}",bname,bid);
return "index";
};
1.3. @RequestBody
@RequestBody注解用于接收请求体的数据,并将其转换为对应的Java对象。通常在处理POST请求时使用,通过该注解,我们可以简化获取请求体数据的过程,直接将数据转换为Java对象,方便后续的业务处理。
@RequestMapping("/hello4/{bid}")
public String hello4(@PathVariable("bid") Integer bid){
// System.out.println("hello springMvc..");
log.info("@PathVariable:bname:{},bid{}",bid);
return "index";
}
1.4. @RequestHeader
@RequestHeader注解用于获取请求头的值,可以指定头部名称和默认值。通过该注解,我们可以方便地获取请求中的头部信息,并根据需要进行相应的处理。例如,可以获取用户的认证信息、浏览器类型等数据。
@RequestMapping("/hello7")
public String hello7( @RequestHeader("jwt") String jwt){
// System.out.println("hello springMvc..");
log.info("@RequestHeader:jwt:{}",jwt);
return "index";
};
二、参数传递
在Spring MVC中,控制器方法可以接收不同类型的参数,包括基础类型、字符串、复杂类型等。
2.1. 基础类型+String
控制器方法可以直接将基本类型和字符串作为参数,Spring MVC会自动进行类型转换。例如,可以直接传递整型、字符型、布尔型等参数,并在方法中进行相应的业务处理。
@ResponseBody
@RequestMapping("/hello2")
public Map hello2(HttpServletResponse response) throws Exception {
Map<String,Object>map=new HashMap<>();
map.put("code",200);
map.put("msg","成功添加");
return map;
}
2.2. 复杂类型
如果请求中包含复杂的参数结构,我们可以定义一个与之对应的Java类,并将其作为控制器方法的参数。Spring MVC将自动将请求参数映射到该Java对象的属性上,提供了一种方便的方式来处理复杂的参数传递。
@RequestMapping("/hello2")
public String index(Book book, HttpServletRequest request){
// System.out.println("hello springMvc..");
log.info("复杂类型参数:bname:{},bid{}",
request.getParameter("bname"),
request.getParameter("bid")
);
log.info("复杂类型参数:bname:{},bid{}",
book.toString()
);
return "index";
}
2.3. @RequestParam
使用@RequestParam注解可以获取请求参数的值,可以指定参数名和默认值。这个注解适用于获取单个参数的值,可以用于基本类型、字符串等参数的获取。
@RequestMapping("/hello3")
public String hello3(@RequestParam String bname,@RequestParam(required = false) Integer bid){
// System.out.println("hello springMvc..");
log.info("@requestParam:bname:{},bid{}",bname,bid);
return "index";
};
2.4. @PathVariable
使用@PathVariable注解可以获取URL路径中的变量值,将路径变量绑定到方法参数上。这个注解适用于RESTful风格的URL处理,可以方便地获取URL中的动态参数。
@RequestMapping("/hello4/{bid}")
public String hello4(@PathVariable("bid") Integer bid){
// System.out.println("hello springMvc..");
log.info("@PathVariable:bname:{},bid{}",bid);
return "index";
};
2.5. @RequestBody
使用@RequestBody注解可以将请求体的数据转换为对应的Java对象,并作为方法的参数。通过该注解,我们可以直接获取请求体中的数据,并进行后续的业务处理。
@RequestMapping("/hello6")
public String hello6( @RequestBody Map map){
// System.out.println("hello springMvc..");
log.info("@RequestBody:map:{}",map);
return "index";
};
2.6. @RequestHeader
使用@RequestHeader注解可以获取请求头的值,可以指定头部名称和默认值。通过该注解,我们可以方便地获取请求头中的信息,并根据需要进行相应的处理。
@RequestMapping("/hello7")
public String hello7( @RequestHeader("jwt") String jwt){
// System.out.println("hello springMvc..");
log.info("@RequestHeader:jwt:{}",jwt);
return "index";
};
三、返回值
在Spring MVC中,控制器方法可以返回不同类型的值作为响应结果,根据业务需求选择合适的返回类型。
3.1. void
如果控制器方法返回值为void,则表示该方法没有返回值。这种情况下,通常是直接向客户端写入数据或者通过其他方式进行响应处理。
public void hello1(HttpServletResponse response) throws Exception {
Map<String,Object>map=new HashMap<>();
map.put("code",200);
map.put("msg","成功添加");
ResponseUtil.writeJson(response,map);
};
3.2. String
控制器方法可以返回一个字符串作为响应结果,这个字符串可以表示视图的名称或者响应的内容。当返回视图名称时,Spring MVC会根据视图解析器的配置找到对应的视图并渲染返回给客户端。
@ResponseBody
@RequestMapping("/hello2")
public Map hello2(HttpServletResponse response) throws Exception {
Map<String,Object>map=new HashMap<>();
map.put("code",200);
map.put("msg","成功添加");
return map;
};
3.3. String+Model
控制器方法可以返回一个字符串和一个Model对象。这种情况下,字符串表示视图的名称,而Model对象用于在视图中传递数据。通过Model对象,我们可以将数据传递到视图中进行展示或者其他业务处理。
@RequestMapping("/hello4")
public String hello4(Model model, HttpServletRequest request) throws Exception {
model.addAttribute("currentName","鸭");
request.setAttribute("location","鸡");
return "index";
};
3.4. ModelAndView
控制器方法可以返回一个ModelAndView对象,它包含了视图名称和数据模型。ModelAndView是一种更加灵活的方式来处理视图和数据的传递,可以同时指定视图名称和数据模型,并在需要的时候进行相应的操作。
@RequestMapping("/hello5")
public ModelAndView hello5(Model model, HttpServletRequest request) throws Exception {
ModelAndView mv=new ModelAndView();
mv.addObject("sign","h");
mv.setViewName("index");
return mv;
};
四、页面跳转
在Spring MVC中,页面跳转可以通过转发(forward)或重定向(redirect)来实现。
@RequestMapping("/hello6")
public String hello6() throws Exception {
System.out.println("hello6");
return "forward:hello2";
};
4.1. 转发(forward)
使用请求转发将请求发送到另一个URL路径上进行处理,客户端的URL地址不会变化。这种方式适用于不同请求之间的跳转和处理,可以共享请求的上下文数据。
@RequestMapping("/hello7")
public String hello7() throws Exception {
System.out.println("hello6");
return "forward:/param//hello1";
};
4.2. 重定向(redirect)
使用重定向将请求发送到另一个URL路径上进行处理,客户端的URL地址会改变。这种方式适用于不同请求之间的跳转和处理,可以避免表单重复提交等问题。
@RequestMapping("/hello9")
public String hello9() throws Exception {
System.out.println("hello6");
return "redirect:/param//hello1";
};
总结:
本文介绍了Spring MVC框架的基础知识和常用注解,以及参数传递、返回值处理和页面跳转等相关内容。掌握了这些知识,我们可以更加灵活地开发Web应用程序,实现不同功能和业务需求。在后续的文章中,我们将深入讨论Spring MVC的更多特性和用法,帮助读者更好地理解和应用该框架。