Spring Boot的Json解析方案

Spring Boot的Json解析方案

1.JSon

@ResponseBody

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

@RequestBody是作用在形参列表上,用于将前台发送过来固定格式的数据【xml格式 或者 json等】封装为对应的 JavaBean 对象,
封装时使用到的一个对象是系统默认配置的 HttpMessageConverter进行解析,然后封装到形参上。

@RequestBody一般写在Controller层,可与@Controller注解合并成@RestContoller。@RestController注解相当于@ResponseBody和@Controller的结合,但是在使用@RestController注解的时候需要注意几个问题:

@RestController

1.如果使用@RestController注解Controller,那么该Controller中的方法就无法返回jsp页面,就是说如果在方法中return "xx",那么它只会返回"xx"的内容,因为@RestController中相当于已经有了@RessponseBody的注解效果,所以它无法返回jsp,html界面,配置的InternalResourceViewResolver不工作,只返回return的内容。

2.根据第一条的规定,如果该Controller中需要返回jsp,html界面,那么就需要使用@Controller注解Controller,不能用@RestController。

3.第一条中说到@RestController注解的Controller只返回return中的内容,所以如果我们在Controller方法中需要返回JSON、XML或者我们自己定义的类型到页面中,那么就需要使用@ResponseBody注解该方法。

//@Controller
@RestController
//@RestController是@Controller和@ResponseBody的组合注解
public class UserController {
    @GetMapping("/user")
    //@ResponseBody>>>>>>将java对象转为json格式的数据。
    public List getAllUser(){
        List users = new ArrayList<>();
        for (int i = 0; i < 10; i++) {
            User user = new User();
            user.setAddress("xxxx");
            user.setName("xxx");
            user.setId(i);
            users.add(user);
        }
        return users;
    }
}

HttpMessageConverter

在项目中对Json数组一般有 返回Json 和 上传Json 两种操作,但不论是返回还是上传都绕不开 HttpMessageConverter(消息转换器),它主要有两方面功能

1.将服务端返回的对象序列化为Json字符串

2.将前端传来的Json字符串反序列化为Java对象

SpringMVC中自动配置了Jackson和Gson的HttpMessageConverter,在SpringBoot中又对其进行了自动化配置,所以,如果用户使用Jackson和Gson时没有其他自定义配置,则直接添加依赖即可。

JacksonHttpMessageConverterConfiguration


image

若添加了Jackson依赖,则该配置类生效,提供了MappingJackson2HttpMessageConverterConfiguration的工具,相当于一个转换工具类。

若想改变Json数组格式,可在声明变量时使用@JsonFormat注解
如:

    @JsonFormat(pattern = "yyyy-MM-dd",timezone = "Asia/Shanghai")
    private Date createDate;

也可使用配置类进行全局配置,用自定义的配置类代替HttpMessageConverter的默认配置

配置类修改Json格式有如下几种方法

1.改写objectMapper,一般用于修改日期格式

    @Bean
    ObjectMapper objectMapper() {
        ObjectMapper om = new ObjectMapper();
        om.setDateFormat(new SimpleDateFormat("yyyy/MM/dd"));
        return om;
    }

2.可用于修改编码格式

    @Bean
    MappingJackson2HttpMessageConverter mappingJackson2HttpMessageConverter() {
        MappingJackson2HttpMessageConverter converter = new MappingJackson2HttpMessageConverter();
        ObjectMapper om = new ObjectMapper();
        om.setDateFormat(new SimpleDateFormat("yyyy/MM/dd"));
        converter.setObjectMapper(om);
        return converter;
    }

==SpringBoot约定大于配置的思想的一种体现==

2.使用Gson处理Json

若要使用Gson,需要先将默认的Jackson移除

  
        
            org.springframework.boot
            spring-boot-starter-web
            
                
                    org.springframework.boot
                    spring-boot-starter-json
                
            
        

再添加Gson的依赖

 
        com.google.code.gson
        gson
    

3.FastJson

fastjson.jar是阿里巴巴开发的一款专门用于Java开发的包,可以方便的实现json对象与JavaBean对象的转换,实现JavaBean对象与json字符串的转换,实现json对象与json字符串的转换。

FastJson需要自己配置HttpMessageConverter

FastJson依赖:


            com.alibaba
            fastjson
            1.2.49
        

配置HttpMessageConverter

    @Bean
    FastJsonHttpMessageConverter fastJsonHttpMessageConverter(){
        FastJsonHttpMessageConverter converter = new FastJsonHttpMessageConverter();
        FastJsonConfig config = new FastJsonConfig();
        //设置UTF8编码格式
        config.setSerializerFeatures(SerializerFeature.PrettyFormat);
        List fastMediaTypes = new ArrayList<>();
        fastMediaTypes.add(MediaType.APPLICATION_JSON_UTF8);
        converter.setSupportedMediaTypes(fastMediaTypes);
        converter.setFastJsonConfig(config);
        //设置日期格式
        config.setDateFormat("yyyy-MM-dd");
        converter.setFastJsonConfig(config);
        return converter;
    }

你可能感兴趣的:(Spring Boot的Json解析方案)