一、GSON简介
GSON是Google公司提供的用来在Java对象和JSON数据之间进行映射的Java类库。可以将一个Json字符转成一个Java对象,或者将一个Java转化为Json字符串。
Gson特点如下:
- 快速、高效
- 代码量少、简洁
- 面向对象
- 数据传递和解析方便
Gson依赖如下:
<dependency>
<groupId>com.google.code.gson</groupId>
<artifactId>gson</artifactId>
</dependency>
注:可以看到我这里的依赖并没有指定版本号,因为Gson在SpringBoot中和Json依赖一样,是Spring官方统一管理版本号,这也是SpringBoot的一大优势,避免了版本号不一致的冲突。
【题外话】
如果想要研究SpringBoot是如何管理依赖的版本可以研究一下如下代码,仔细研究会有惊喜。打开spring-boot-starter-parent.pom文件,可以试着研究一下其中的源码。
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.2.4.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
二、各个JSON技术(Jackson,Gson,Fastjson)的对比
【1.json-lib】
优势:
- json-lib最开始也是应用最广泛的json解析工具。(现在没有优势了)
劣势:
- 依赖于很多第三方包,包含·commons-beanutils.jar、commons-collections-3.2.jar、commons-lang-2.6.jar、commons-logging-1.1.1.jar、ezmorph-1.0.6.jar。
- 对于复杂类型的转换,json-lib对于json转换成bean还有缺陷,比如一个类里面会出现另一个类的list或者map集合,json-lib从json到bean的转换就会出现问题。
- json-lib在功能和性能上面都不能满足现在互联网化的需求。
【2.开源的Jackson】
优势:
- 相比json-lib框架,Jackson所依赖的jar包较少,简单易用并且性能也要相对高些。
- Jackson社区相对比较活跃,更新速度也比较快。
劣势:
- Jackson对于复杂类型的json转换bean会出现问题,一些集合Map,List的转换出现问题。
- Jackson对于复杂类型的bean转换Json,转换的json格式不是标准的Json格式。
【3.Google的Gson】
优势:
- Gson是目前功能最全的Json解析神器,Gson当初是因为应Google公司内部需求而由Google自行研发而来,但自从在2008年五月公开发布第一版后已被许多公司或用户应用。
- Gson的应用主要为toJson与fromJson两个转换函数,无依赖,不需要额外的jar,能够直接跑在JDK上。
- 类里面只要有get和set方法,Gson完全可以将复杂类型的json到bean或bean到json的转换,是JSON解析的神器。(使用这种对象转换之前需先创建好对象的类型以及其成员才能成功的将JSON字符串成功转换成相对应的对象。)
劣势:
- Gson在功能上面无可挑剔,但是性能上面相比阿里的FastJson还是有所差距。
【4.阿里巴巴的FastJson】
优势:
- Fastjson是一个Java语言编写的高性能的JSON处理器,由阿里巴巴公司开发,无依赖,不需要额外的jar,能够直接跑在JDK上。
- FastJson采用独创的算法,将parse的速度提升到极致,超过所有json库。
劣势:
- FastJson在复杂类型的Bean转换Json上会出现一些问题,可能会出现引用的类型,导致Json转换出错,需要制定引用。
【总结】
综上4种Json技术的比较,在项目选型的时候可以使用Google的Gson和阿里巴巴的FastJson两种并行使用,如果只是功能要求,没有性能要求,可以使用google的Gson,如果有性能上面的要求可以使用Gson将bean转换json确保数据的正确,使用FastJson将Json转换Bean,发挥FastJson解析性能上的优势。
三、如何使用Gson
在此之前,先说明一下,Gson使用方式和Json比较相似,可以参考我的上一篇文章,先了解一下Json,SpringBoot默认的JSON解析方案。
学习Gson,只需要在Json项目上稍加改造即可,具体操作如下:
【第一步】在pom.xml文件中,去除json依赖,添加Gson依赖即可。
【去除json依赖】
<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>
注:因为是SpringBoot项目,所以不需要指定版本号,但我这里我使用的版本是
<version>2.8.6</version>
【第二步】改造上一篇文章的WebMvcConfig.java,代码如下:
package com.mango.gson.config;
import com.google.gson.Gson;
import com.google.gson.GsonBuilder;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.http.converter.json.GsonHttpMessageConverter;
@Configuration
public class WebMvcConfig {
@Bean
GsonHttpMessageConverter gsonHttpMessageConverter(){
GsonHttpMessageConverter converter = new GsonHttpMessageConverter();
converter.setGson(new GsonBuilder().setDateFormat("yyyy-MM-dd").create());
return converter;
}
}
【改进版】和上一篇中的ObjectMapper一样,不同的是,这里使用的是Gson,所以只需要重写Gson即可,代码如下:
package com.mango.gson.config;
import com.google.gson.Gson;
import com.google.gson.GsonBuilder;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.http.converter.json.GsonHttpMessageConverter;
@Configuration
public class WebMvcConfig {
@Bean
Gson gson(){
return new GsonBuilder().setDateFormat("yyyy-MM-dd").create();
}
}
注:在上一篇文章中,提供了源码路径,今天学习Gson也一样,这里我也提供源码路径,和上一篇中的Json学习方式相同。
【GsonHttpMessageConvertersConfiguration.java源码路径】
org.springframework.boot.autoconfigure.http.GsonHttpMessageConvertersConfiguration
【GsonAutoConfiguration.java源码路径】
org.springframework.boot.autoconfigure.gson.GsonAutoConfiguration
最后说一下,对比学习两者之前的相同和不同之处,这样知识点容易记得住,也不容易忘记,祝大家学习愉快。