9. SpringMVC处理ajax请求
阅读原文时间:2023年08月29日阅读:1

@RequestBody 可以获取请求体信息,使用@RequestBody 注解标识控制器方法的形参,当前请求的请求体就会为当前注解所标识的形参赋值

<!--此时必须使用post请求方式,因为get请求没有请求体-->
<form th:action="@{/test/RequestBody}" method="post">
  &nbsp; 用户名:<input type="text" name="username" /><br />
  &nbsp; 密码:<input type="password" name="password" /><br />
  &nbsp; &nbsp;<input type="submit" />
</form>


@RequestMapping("/test/RequestBody")
public String testRequestBody(@RequestBody String requestBody){
 &nbsp; &nbsp;System.out.println("requestBody:"+requestBody);
 &nbsp; &nbsp;return "success";
}

输出结果:

requestBody:username=admin&password=123456

在使用了 axios 发送 ajax 请求之后,浏览器发送到服务器的请求参数有两种格式:

1、name=value&name=value…,此时的请求参数可以通过 request.getParameter()获取,对应

SpringMVC 中,可以直接通过控制器方法的形参获取此类请求参数

2、{key:value,key:value,…},此时无法通过 request.getParameter()获取,之前我们使用操作

json 的相关 jar 包 gson 或 jackson 处理此类请求参数,可以将其转换为指定的实体类对象或 map 集

合。在 SpringMVC 中,直接使用@RequestBody 注解标识控制器方法的形参即可将此类请求参数

转换为 java 对象

使用@RequestBody 获取 json 格式的请求参数的条件:

1、导入 jackson 的依赖

<dependency>
 &nbsp; &nbsp;<groupId>com.fasterxml.jackson.core</groupId>
 &nbsp; &nbsp;<artifactId>jackson-databind</artifactId>
 &nbsp; &nbsp;<version>2.12.1</version>
</dependency>

2、SpringMVC 的配置文件中设置开启 mvc 的注解驱动

<!--开启mvc的注解驱动-->
<mvc:annotation-driven />

3、在控制器方法的形参位置,设置 json 格式的请求参数要转换成的 java 类型(实体类或 map)的参

数,并使用@RequestBody 注解标识

<input
  type="button"
  value="测试@RequestBody获取json格式的请求参数"
  @click="testRequestBody()"
/><br />
<script type="text/javascript" th:src="@{/js/vue.js}"></script>
<script type="text/javascript" th:src="@{/js/axios.min.js}"></script>
<script type="text/javascript">
  var vue = new Vue({
    el: "#app",
    methods: {
      testRequestBody() {
        axios
          .post("/SpringMVC/test/RequestBody/json", {
            username: "admin",
            password: "123456",
          })
          .then((response) => {
            console.log(response.data);
          });
      },
    },
  });
</script>


//将json格式的数据转换为map集合
@RequestMapping("/test/RequestBody/json")
public void testRequestBody(@RequestBody Map<String, Object> map,HttpServletResponse response) throws IOException {
 &nbsp; &nbsp;System.out.println(map);
 &nbsp; &nbsp;//{username=admin, password=123456}
 &nbsp; &nbsp;response.getWriter().print("hello,axios");
}
//将json格式的数据转换为实体类对象
@RequestMapping("/test/RequestBody/json")
public void testRequestBody(@RequestBody User user, HttpServletResponseresponse) throws IOException {
 &nbsp; &nbsp;System.out.println(user);
 &nbsp; &nbsp;//User{id=null, username='admin', password='123456', age=null,gender='null'}
    response.getWriter().print("hello,axios");
}

@ResponseBody 用于标识一个控制器方法,可以将该方法的返回值直接作为响应报文的响应体响应到浏览器

@RequestMapping("/testResponseBody")
public String testResponseBody(){
 &nbsp; &nbsp;//此时会跳转到逻辑视图success所对应的页面
 &nbsp; &nbsp;return "success";
}
@RequestMapping("/testResponseBody")
@ResponseBody
public String testResponseBody(){
 &nbsp; &nbsp;//此时响应浏览器数据success
 &nbsp; &nbsp;return "success";
}

服务器处理 ajax 请求之后,大多数情况都需要向浏览器响应一个 java 对象,此时必须将 java 对象转换为

json 字符串才可以响应到浏览器,之前我们使用操作 json 数据的 jar 包 gson 或 jackson 将 java 对象转换为

json 字符串。在 SpringMVC 中,我们可以直接使用@ResponseBody 注解实现此功能

@ResponseBody 响应浏览器 json 数据的条件:

1、导入 jackson 的依赖

<dependency>
 &nbsp; &nbsp;<groupId>com.fasterxml.jackson.core</groupId>
 &nbsp; &nbsp;<artifactId>jackson-databind</artifactId>
 &nbsp; &nbsp;<version>2.12.1</version>
</dependency>

2、SpringMVC 的配置文件中设置开启 mvc 的注解驱动

<!--开启mvc的注解驱动-->
<mvc:annotation-driven />

3、使用@ResponseBody 注解标识控制器方法,在方法中,将需要转换为 json 字符串并响应到浏览器

的 java 对象作为控制器方法的返回值,此时 SpringMVC 就可以将此对象直接转换为 json 字符串并响应到浏览器

<input
  type="button"
  value="测试@ResponseBody响应浏览器json格式的数据"
  @click="testResponseBody()"
/><br />
<script type="text/javascript" th:src="@{/js/vue.js}"></script>
<script type="text/javascript" th:src="@{/js/axios.min.js}"></script>
<script type="text/javascript">
  var vue = new Vue({
    el: "#app",
    methods: {
      testResponseBody() {
        axios.post("/SpringMVC/test/ResponseBody/json").then((response) => {
          console.log(response.data);
        });
      },
    },
  });
</script>


//响应浏览器list集合
@RequestMapping("/test/ResponseBody/json")
@ResponseBody
public List<User> testResponseBody(){
 &nbsp; &nbsp;User user1 = new User(1001,"admin1","123456",23,"男");
 &nbsp; &nbsp;User user2 = new User(1002,"admin2","123456",23,"男");
 &nbsp; &nbsp;User user3 = new User(1003,"admin3","123456",23,"男");
 &nbsp; &nbsp;List<User> list = Arrays.asList(user1, user2, user3);
 &nbsp; &nbsp;return list;
}
//响应浏览器map集合
@RequestMapping("/test/ResponseBody/json")
@ResponseBody
public Map<String, Object> testResponseBody(){
 &nbsp; &nbsp;User user1 = new User(1001,"admin1","123456",23,"男");
 &nbsp; &nbsp;User user2 = new User(1002,"admin2","123456",23,"男");
 &nbsp; &nbsp;User user3 = new User(1003,"admin3","123456",23,"男");
 &nbsp; &nbsp;Map<String, Object> map = new HashMap<>();
 &nbsp; &nbsp;map.put("1001", user1);
 &nbsp; &nbsp;map.put("1002", user2);
 &nbsp; &nbsp;map.put("1003", user3);
 &nbsp; &nbsp;return map;
}
//响应浏览器实体类对象
@RequestMapping("/test/ResponseBody/json")
@ResponseBody
public User testResponseBody(){
 &nbsp; &nbsp;return user;
}

@RestController 注解是 springMVC 提供的一个复合注解,标识在控制器的类上,就相当于为类添加了

@Controller 注解,并且为其中的每个方法添加了@ResponseBody 注解