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<User> getAllUser(){
List<User> 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
若添加了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移除
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
<exclusions>
<exclusion>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-json</artifactId>
</exclusion>
</exclusions>
</dependency>
再添加Gson的依赖
<dependency>
<groupId>com.google.code.gson</groupId>
<artifactId>gson</artifactId>
</dependency>
3.FastJson
fastjson.jar是阿里巴巴开发的一款专门用于Java开发的包,可以方便的实现json对象与JavaBean对象的转换,实现JavaBean对象与json字符串的转换,实现json对象与json字符串的转换。
FastJson需要自己配置HttpMessageConverter
FastJson依赖:
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>fastjson</artifactId>
<version>1.2.49</version>
</dependency>
配置HttpMessageConverter
@Bean
FastJsonHttpMessageConverter fastJsonHttpMessageConverter(){
FastJsonHttpMessageConverter converter = new FastJsonHttpMessageConverter();
FastJsonConfig config = new FastJsonConfig();
//设置UTF8编码格式
config.setSerializerFeatures(SerializerFeature.PrettyFormat);
List<MediaType> 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;
}