Spring MVC之Json处理

Json作为客户端和服务器端数据交换的一种很重要的数据交换格式,应用非常广泛,那么如何在Spring MVC中处理Json(接收,转化,响应…)

Json

Spring MVC默认使用的Json解决方案选择的是Jackson,所以只需要导入Jackson的依赖就可以使用了

导入依赖

        <!-- Jackson -->
        <dependency>
            <groupId>com.fasterxml.jackson.core</groupId>
            <artifactId>jackson-databind</artifactId>
            <version>2.4.2</version>
        </dependency>

使用@ResponseBody

这个注解的作用是将返回值自动转为json并返回给客户端

我们假定在处理业务时需要返回给客户端一个Employee的对象

    @RequestMapping("test1")
    @ResponseBody   //这个注解的作用是将返回值自动转为json并返回给客户端
    public Employee test1(){
        System.out.println("test1");
        Employee employee = new Employee(1,"leiyu",true);
        return employee;
    }
  • 注意方法返回值,renturn直接返回的是我们获取到的employee对象,,由SpringMVC自动为我们转化为json,需要添加@ResponseBody注解

小总结:当以后我们需要用到json数据时,只需要添加这个注解,并直接返回

@ResponseBody注解适合所有的对象类型,不论是实体,还是集合…等

    @RequestMapping("test2")
    @ResponseBody
    public List<Employee> test2(){
        System.out.println("test2  json转化复杂对象,或者说嵌套对象");
        Employee employee = new Employee(1,"leiyu",true);
        Employee employee1 = new Employee(1,"小白",false);
        List<Employee> employeeList = Arrays.asList(employee,employee1);
        return employeeList;
    }

特例:@ResponseBody对字符串无转化效果

  • 只有当返回值不是字符串时才会帮我们转化
  • 如果是字符串类型,那么就会直接输出字符串的内容
  • 观察这个示例,发现加了@ResponseBody注解之后,使用return返回的不再是一个页面,而是将字符直接响应给客户端
    @RequestMapping("test3")
    @ResponseBody
    public String test3(){
        System.out.println("注解对原本就是字符串的无转化,直接输出");
        return "ok";//因为加了注解,这里不再转发到页面而是返回一个json字符串,而这个又是字符串类型,因为直接输出字符
    }
    //如果字符串是中文,那么要要设置字符集,不然会中文乱码
    @RequestMapping(value = "test4",produces = "text/html;charset=utf-8")
    @ResponseBody
    public String test4(){
        System.out.println("注解对原本就是字符串的无转化,直接输出");
        return "ok";//因为加了注解,这里不再转发到页面而是返回一个json字符串,而这个又是字符串类型,因为直接输出
    }
  • 如果需要响应的字符串是中文,那么需要设置字符集 produces="text/html;charset=utf-8"
  • 细心的读者发现我们之前在封装实体对象或者集合等类型时,虽然也有中文,但是不需要设置字符集,是因为在Jackson中已经为我们封装好了关于对象转化为json的字符集,而在字符串是直接响应,不再将字符串转化为json,也就没有封装字符集,需要我们自己封装.

@RestController

@RestController中封装了@Controller注解,在类的上写@RestController一方面表示这个类是一个控制器类,另一方面,它会为该控制器中的所有handler都自动封装一个@ResponseBody注解,就意味着在该控制器中的每个handler都需要返回一个json格式的数据

在@RestController中封装了@Controller
image-20200625082926858
@RequestMapping("employee")
@RestController
public class EmployeeController {
    @RequestMapping("test1")
    //@ResponseBody   因为有了@RestController注解,在handler中就不需要在写这个注解
    public Employee test1(){
        System.out.println("test1");
        Employee employee = new Employee(1,"leiyu",true);
        return employee;
    }
}

@RequestBody

使用@RequestBody,接收Json参数

定义Handler

public class User {
    private Integer id;
    private String name;
    private Boolean gender;
    private Date birthday;
}

定义去值方法


    @RequestMapping("test2")
    @ResponseBody
    public String test2(@RequestBody User user){
        System.out.println(user);
        return "ok";

    }

Ajax发送Json请求

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>Json接收响应</title>
    <script src="${pageContext.request.contextPath}/js/jquery-1.10.2.js"></script>
</head>
<body>


    <input type="button" value="ajax" οnclick="send_json();">
    <script>
        function send_json() {
            var  user = {id:1,name:"雷雨"};
            var userJson = JSON.stringify(user);
            $.ajax({
                url:"${pageContext.request.contextPath}json/test2",
                type:"post",
                data:userJson,
                contentType:"application/json",
                success:function (ret) {
                    alert(ret);
                }
            })
        }
    </script>
</body>
</html>

Jackson常用注解

日期转化

在日期转json时,默认使用的是日期的毫秒数

可阅读性不强,因为需要使用到日期的格式化

使用注解@JsonFormat(pattern="yyyy-MM-dd HH:mm:ss",timezone="GMT+8")

  • pattern的参数的时期格式化的格式
  • timezone表示的是日期的时区,我们在东八区因为加8
public class User {
    private Integer id;
    private String name;
    private Boolean gender;
    @JsonFormat(pattern = "yyyy-MMM-dd HH:mm:ss",timezone = "GMT+8")
    private Date birthday;
    ...
    get/set
}

属性忽略

@JsonIgnore

在实体类的属性上加这个注解,那么会在生成Json时忽略该属性

属性名修改

@JsonProperty(“new_name”)

在实体类的属性上加这个注解,那么会在生成Json时使用新的属性名作为Json格式的属性名

null和empty属性排除

Jackson默认输出null值的属性,如果不需要,可以排除

  • @JsonInclude(JsonInlude.Include.NON_NULL):表示null值 属性不输出
  • @JsonInclude(JsonInlude.Include.NON_EMPTY):empty属性不输出(空串,长度为0的集合,null值)

自定义序列化

@JsonSerialize(using= Myserializer.class) ,使用Myserializer输出某属性

Fastjson

如果不想使用Jackson,那么也可以使用FastJson,由于FastJson不是MVC的默认依赖方案,因此需要自己额外带入依赖和安装

导入依赖

<dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>fastjson</artifactId>
    <version>1.1.37</version>
</dependency>

安装FastJson

    <mvc:annotation-driven>
        <!--安装FstJson,转换器 -->
        <mvc:message-converters>
            <bean class="com.alibaba.fastjson.support.spring.FastJsonHttpMessageConverter">
                <property name="supportedMediaTypes">
                    <list>
                        <value>application/json</value>
                    </list>
                </property>
            </bean>
        </mvc:message-converters>
    </mvc:annotation-driven>

使用

@ResponseBody @RequestBody @RestController使用方法不变

常用注解

  • 日期格式化:@FSONField(format=“yyyy/MM/dd”)
  • 属性名修改: @JSONField(name=“birth”)
  • 属性忽略: @JSONField(serialize = false)
  • 包含null值:@JSONField(serializeFeatures = SerillizeFeature.WriteMapNullValue) 默认忽略所有null值,有此注解会输出null
    • @JSONField(serialzeFeatures=SerializeFeature.WriteNullStringAsEmpty)
  • 自定义序列化:@JSONField(serializeUsing = MySerializer2.class)
    • MySerializer2是我们写的自定义的序列化的类

我是雷雨,一个普本科的学生,主要专注于Java后端和大数据开发

如果这篇文章有帮助到你,希望你给我一个大大的赞
如果有什么问题,希望你能留言和我一起研究,学习靠自觉,分享靠自愿

转载注明出处
https://blog.csdn.net/qq_40742223

猜你喜欢

转载自blog.csdn.net/qq_40742223/article/details/106978221
今日推荐