飞道的博客

SpringMVC对json数据的处理

371人阅读  评论(0)

   1.SpringMVC对json格式数据的支持

  • SpringMVC使用HttpMessageConverter处理json,使用HttpMessageConverter<T>将请求信息转化并绑定到处理方法的入参中或将相应结果转为对应的相应的响应信息,spring提供@RequestBody/@responseBody对处理方法进行标注。
  • 当控制器处理方法使用到 @RequestBody/@ResponseBody ,Spring 首先根据请求头或响应头的 Accept 属性选择匹配的 HttpMessageConverter进而根据参数类型或泛型类型的过滤得到匹配的 HttpMessageConverter, 若找不到可用的 HttpMessageConverter 将报错
  • 请求和响应中的数据转换
  • HttpMessageConverter<T> 的实现类
  • @ResponseBody的作用其实是将java对象转为json格式的数据。

      @responseBody注解的作用是将controller的方法返回的对象通过适当的转换器转换为指定的格式之后,写入到response对象的body区,通常用来返回JSON数据或者是XML数据。

      注意:在使用此注解之后不会再走视图处理器,而是直接将数据写入到输入流中,他的效果等同于通过response对象输出指定格式的数据。

2.代码演示

1.请求json,返回json

    加入json的处理jar

    

    jar链接:https://pan.baidu.com/s/18-A0ZCABISQV00twtgkYkg

    提取码:ojh0

(1)requestJson.jsp


  
  1. <%@ page language="java" contentType="text/html; charset=UTF-8"
  2. pageEncoding= "UTF-8"%>
  3. <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
  4. <html>
  5. <head>
  6. <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
  7. <title>Insert title here </title>
  8. <script type="text/javascript"
  9. src= "${pageContext.request.contextPath}/scripts/jquery-1.7.2.min.js"> </script>
  10. <script type="text/javascript">
  11. function requestJson() {
  12. //模仿json格式的数据
  13. var jsonUser = JSON.stringify({ "username": "张三", "age": "18", "address": "朔州"});
  14. $.ajax({
  15. type: 'post',
  16. url: '${pageContext.request.contextPath}/json/requestJson',
  17. contentType: 'application/json;charset=utf-8',
  18. data:jsonUser,
  19. //回调函数,查看到底成不成功
  20. success: function(data){
  21. alert(data);
  22. }
  23. })
  24. }
  25. }
  26. </script>
  27. </head>
  28. <body>
  29. <input type="button" value="请求json,返回json" onclick="requestJson()">
  30. <input type="button" value="请求pojo,返回json" onclick="requestPojo()">
  31. </body>
  32. </html>

 

(2)controller


  
  1. @RequestMapping("/json")
  2. @Controller
  3. public class JsonController {
  4. //接受json的数据 使用 RequsetBody把json格式数据封装到User对象
  5. //返回User对象,使用ResponseBody把User对象转成json对象
  6. @RequestMapping("/requestJson")
  7. public @ResponseBody User1 requestJson( @RequestBody User1 user){
  8. System. out.println(user);
  9. return user;
  10. }
  11. }

我们进行debug调试,浏览器进行访问,通过开者工具Sources查看json的请求和返回

说明json格式数据转换成功了,可以进行请求了

说明返回json数据成功了

2.请求Pojo,返回json

(1)requestJson.jsp


  
  1. <%@ page language="java" contentType="text/html; charset=UTF-8"
  2. pageEncoding= "UTF-8"%>
  3. <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
  4. <html>
  5. <head>
  6. <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
  7. <title>Insert title here </title>
  8. <script type="text/javascript"
  9. src= "${pageContext.request.contextPath}/scripts/jquery-1.7.2.min.js"> </script>
  10. <script type="text/javascript">
  11. function requestPojo() {
  12. $.ajax({
  13. type: 'post',
  14. url: '${pageContext.request.contextPath}/json/requestPojo',
  15. //模仿javaBean
  16. data: 'username=张&age=13&address=上海',
  17. //回调函数,查看到底成不成功
  18. success: function(data){
  19. alert(data);
  20. }
  21. })
  22. }
  23. </script>
  24. </head>
  25. <body>
  26. <input type="button" value="请求json,返回json" onclick="requestJson()">
  27. <input type="button" value="请求pojo,返回json" onclick="requestPojo()">
  28. </body>
  29. </html>

(2)contoller


  
  1. package com.hbsi.springmvc.json;
  2. import org.springframework.stereotype.Controller;
  3. import org.springframework.web.bind. annotation.RequestBody;
  4. import org.springframework.web.bind. annotation.RequestMapping;
  5. import org.springframework.web.bind. annotation.ResponseBody;
  6. import com.hbsi.springmvc.bean.User1;
  7. @RequestMapping("/json")
  8. @Controller
  9. public class JsonController {
  10. //请求POJO返回json
  11. @RequestMapping("/requestPojo")
  12. public @ResponseBody User1 requestPojo(User1 user){
  13. System. out.println(user);
  14. return user;
  15. }
  16. }

我们进行debug调试,浏览器进行访问,通过开者工具Sources查看json的请求和返回

说明请求pojo,返回pojo成功了


转载:https://blog.csdn.net/lbqlzch/article/details/106178631
查看评论
* 以上用户言论只代表其个人观点,不代表本网站的观点或立场