3.3.1、@RequestParam范例一🔥
要求定义个接口,该接口请求路径要求为 /testRequestParam,请求方式无要求。参数为id和name和likes。使用QueryString的格式传递。
3.3.1.1、参数单独获取🔥
如果我们想把id,name,likes单独获取出来可以使用如下写法:
- 在方法中定义方法参数,方法参数名要和请求参数名一致,这种情况下我们可以省略
@RequestParam
注解。
@RequestMapping("/testRquestParam")
public String testRquestParam(Integer id, String name, String[] likes){
System.out.println(“testRquestParam”);
System.out.println(id);
System.out.println(name);
System.out.println(Arrays.toString(likes));
return “/success.jsp”;
}
- 如果方法参数名和请求参数名不一致,我们可以加上
@RequestParam
注解例如:
@RequestMapping("/testRquestParam")
public String testRquestParam(@RequestParam(“id”) Integer uid,@RequestParam(“name”) String name, @RequestParam(“likes”)String[] likes){
System.out.println(“testRquestParam”);
System.out.println(uid);
System.out.println(name);
System.out.println(Arrays.toString(likes));
return “/success.jsp”;
}
3.3.1.2、获取参数封装成实体对象🔥
如果我们想把这些参数封装到一个User对象中可以使用如下写法:
- 注意:获取参数封装成实体对象不需要加@RequestBody注解
@RequestMapping("/testRquestParam")
//获取参数封装成实体对象不需要加@RequestBody注解
public String testRquestParam(User user){
System.out.println(“testRquestParam”);
System.out.println(user);
return “/success.jsp”;
}
User类定义如下:
@Data
@NoArgsConstructor
@AllArgsConstructor
public class User {
private Integer id;
private String name;
private Integer age;
private String[] likes;
}
测试时请求url如下:
http://localhost:8080/testRquestParam?id=1&name=三更草堂&likes=编程&likes=录课&likes=LOL
注意:实体类中的成员变量要和请求参数名对应上。并且要提供对应的set/get方法。
3.4.1、required🔥
-
代表是否必须,默认值为true也就是必须要有对应的参数。如果没有就会报错。
-
如果对应的参数可传可不传则可以把去设置为fasle
例如:
@RequestMapping("/testRquestParam")
public String testRquestParam(@RequestParam(value = “id”,required = false) Integer uid,@RequestParam(“name”) Strcing name, @RequestParam(“likes”)String[] likes){
System.out.println(“testRquestParam”);
System.out.println(uid);
System.out.println(name);
System.out.println(Arrays.toString(likes));
return “/success.jsp”;
}
此时测试时请求uri如下:
// 可以选择传id
http://localhost:8080/testRquestParam?id=1&name=三更草堂&likes=编程&likes=录课&likes=LOL
// 也可以选择不传id
http://localhost:8080/testRquestParam?name=三更草堂&likes=编程&likes=录课&likes=LOL
3.4.2、defaultValue🔥
如果对应的参数没有传参,我们可以用defaultValue属性设置默认值。
@RequestMapping("/testRquestParam")
public String testRquestParam(@RequestParam(value = “id”,required = false,defaultValue = “777”) Integer uid,@RequestParam(“name”) String name, @RequestParam(“likes”)String[] likes){
System.out.println(“testRquestParam”);
System.out.println(uid);
System.out.println(name);
System.out.println(Arrays.toString(likes));
return “/success.jsp”;
}
===========================================================================
虽然我们前面在获取参数时看起来非常轻松,但是在这个过程中是有可能出现一些问题的。
例如,请求参数为success=1 我们期望把这个请求参数获取出来赋值给一个Boolean类型的变量。
这里就会涉及到 Stirng-——>Boolean的类型转换了。实际上SpringMVC中内置了很多类型转换器来进行类型转换。也有专门进行Stirng-——>Boolean类型转换的转换器StringToBooleanConverter。
如果是符合SpringMVC内置转换器的转换规则就可以很轻松的实现转换。但是如果不符合转换器的规则呢?
例如,请求参数为birthday=2004-12-12 我们期望把这个请求参数获取出来赋值给一个Date类型的变量。就不符合内置的规则了。内置的可以把 2004/12/12 这种格式进行转换。这种情况下我们就可以选择自定义类型转换。
①创建类实现Converter接口
字符串String 到 日期类型Date 类型转换
public class StringToDateConverter implements Converter<String, Date> {
public Date convert(String source) {
return null;
}
}
②实现convert方法
public class StringToDateConverter implements Converter<String, Date> {
public Date convert(String source) {
//String->Date 2005-12-12
Date date = null;
try {
SimpleDateFormat simpleDateFormat = new SimpleDateFormat(“yyyy-MM-dd”);
date = simpleDateFormat.parse(source);
} catch (ParseException e) {
e.printStackTrace();
}
return date;
}
}
③配置让SpringMVC使用自定义转换器
<mvc:annotation-driven conversion-service=“myConversionService”>
mvc:message-converters
</mvc:message-converters>
</mvc:annotation-driven>
=============================================================================
无论是RestFul风格还是我们之前web阶段接触过的异步请求,都需要把数据转换成Json放入响应体中。
SpringMVC为我们提供了@ResponseBody
来非常方便的把Json放到响应体中。
位置:类上或方法上(查看源码得知)
-
类上:此类中所有方法的返回值都放入响应体中
-
方法上:此方法的返回值放入响应体中
SpringMVC可以把我们进行Json的转换,不过需要进行相应配置
5.2.1、配置🔥
- 导入jackson依赖
com.fasterxml.jackson.core
jackson-databind
2.9.0
- 开启mvc的注解驱动
mvc:annotation-driven</mvc:annotation-driven>
5.2.2、@ResponseBody范例一
-
只要把要转换的数据直接作为方法的返回值返回即可。
-
SpringMVC会帮我们把返回值转换成json
要求定义个RestFul风格的接口,该接口可以用来根据id查询用户。请求路径要求为 /response/user ,请求方式要求为GET。而请求参数id要写在请求路径上,例如 /response/user/1 这里的1就是id。要求获取参数id,去查询对应id的用户信息(模拟查询即可,可以选择直接new一个User对象),并且转换成json响应到响应体中。
@Controller
@RequestMapping("/response")
public class ResponseController {
@GetMapping("/user/{id}")
@ResponseBody //将这方法的返回值放入响应体中
public User testResponse(@PathVariable Integer id){
User user = new User(id,null,null,null);
return user;//因为做过json配置,所以会把返回值转换成json
}
}
5.2.3、@ResponseBody范例二
要求定义个RestFul风格的接口,该接口可以查询所有用户。请求路径要求为 /response/user ,请求方式要求为GET。去查询所有的用户信息(模拟查询即可,可以选择直接创建集合,添加几个User对象),并且转换成json响应到响应体中。
@Controller
@RequestMapping("/response")
@ResponseBody //此类中所有方法的返回值都会放到响应体中
public class ResponseController {
@GetMapping("/user/{id}")
public User testResponse(@PathVariable Integer id){
User user = new User(id,null,null,null);
return user;
}
@GetMapping("/user")
public List testResponse2(){
List list = new ArrayList();
list.add(new User(1,“三更”,15,null));
list.add(new User(2,“四更”,16,null));
list.add(new User(3,“五更”,17,null));
return list;
}
}
此时@ResponseBody
加在类上,表示改类中的所有方法的返回值都会放到响应体中。并且转化为Json格式。
我们可以使用@RestController
注解替换@Controller
和@ResponseBody
两个注解
@RequestMapping("/response")
@RestController //相当于 @Controller+@ResponseBody
public class ResponseController {
@GetMapping("/user/{id}")
public User testResponse(@PathVariable Integer id){
User user = new User(id,null,null,null);
return user;
}
@GetMapping("/user")
public List testResponse2(){
List list = new ArrayList();
list.add(new User(1,“三更”,15,null));
list.add(new User(2,“四更”,16,null));
list.add(new User(3,“五更”,17,null));
return list;
}
}
============================================================================
我们之前在web阶段我们经常要使用到request对象,response,session对象等。我们也可以通过SpringMVC获取到这些对象。(不过在MVC中我们很少获取这些对象,因为有更简便的方式,避免了我们使用这些原生对象相对繁琐的API。)
我们只需要在方法上添加对应类型的参数即可,但是注意数据类型不要写错了,SpringMVC会把我们需要的对象传给我们的形参。
例如:
@Controller
public class RequestResponseController {
@RequestMapping("/getReqAndRes")
public String getReqAndRes(HttpServletRequest request, HttpServletResponse response, HttpSession session){
System.out.println();
return “test”;
}
}
==================================================================================
在方法中定义一个参数,参数前加上@RequestHeader
注解,知道要获取的请求头名即可获取对应请求头的值。
例如:
想要获取 device-type 这个请求头则可以按照如下方式定义方法。
@Controller
public class RequestResponseController {
@RequestMapping("/getHeader")
public String getHeader(@RequestHeader(value = “device-type”) String deviceType){
System.out.println(deviceType);
return “test”;
}
}
在方法中定义一个参数,参数前加上@CookieValue
注解,知道要获取的cookie名即可获取对应cookie的值。
例如:
想要获取 JSESSIONID 的cookie值。则可以按照如下方式定义方法。
@Controller
public class RequestResponseController {
@RequestMapping("/getCookie")
public String getCookie(@CookieValue(“JSESSIONID”) String sessionId){
System.out.println(sessionId);
return “test”;
}
}
===============================================================================
如果我们使用JSP进行开发,那我们就需要在域中存数据,然后跳转到对应的JSP页面中,在JSP页面中获取域中的数据然后进行相关处理。
使用如果是类似JSP的开发模式就会涉及到往域中存数据和携带数据跳转页面的操作。
所以我们来看下如果用SpringMVC进行相关操作。
8.1.1、使用Model
我们可以使用Model来往域中存数据。然后使用之前的方式实现页面跳转。
例如:
我们要求访问 /testRequestScope 这个路径时能往Request域中存name和title数据,然后跳转到 /WEB-INF/page/testScope.jsp 这个页面。在Jsp中获取域中的数据。
则可以使用如下写法:
@Controller
public class JspController {
@RequestMapping("/testRquestScope")
public String testRquestScope(Model model){
//往请求域存数据
model.addAttribute(“name”,“三更”);
model.addAttribute(“title”,“不知名Java教程UP主”);
return “testScope”;
}
}
8.1.2、使用ModelAndView
我们可以使用ModelAndView来往域中存数据和页面跳转。
例如:
我们要求访问 /testRequestScope2 这个路径时能往域中存name和title数据,然后跳转到 /WEB-INF/page/testScope.jsp 这个页面。在Jsp中获取域中的数据。
则可以使用如下写法:
@Controller
public class JspController {
@RequestMapping("/testRquestSc
《一线大厂Java面试题解析+后端开发学习笔记+最新架构讲解视频+实战项目源码讲义》
【docs.qq.com/doc/DSmxTbFJ1cmN1R2dB】 完整内容开源分享
ope2")
public ModelAndView testRquestScope2(ModelAndView modelAndView){
//往域中添加数据
modelAndView.addObject(“name”,“三更”);
modelAndView.addObject(“title”,“不知名Java教程UP主”);
//页面跳转
modelAndView.setViewName(“testScope”);
return modelAndView;
}
}
- 注意要把modelAndView对象作为方法的返回值返回
我们可以使用@RequestAttribute
把他加在方法参数上,可以让SpringMVC帮我们从Request域中获取相关数据。
例如:
@Controller
public class JspController {
@RequestMapping("/testGetAttribute")
public String testGetAttribute(@RequestAttribute(“org.springframework.web.servlet.HandlerMapping.bestMatchingPattern”)String value,HttpServletRequest request){
System.out.println(value);
return “testScope”;
}
}
我们可以使用@SessionAttributes
注解来进行标识,用里面的属性来标识哪些数据要存入Session域。
例如
我们要求访问 /testSessionScope 这个路径时能往域中存name和title数据,然后跳转到 /WEB-INF/page/testScope.jsp 这个页面。在jsp中获取Session域中的数据。
位置:类上