Java使用GSON对JSON进行解析——IDEA引入jar包方式

16 篇文章 2 订阅

GSON

GSON是Google公司开发的用于解析json的类库。可以很轻松地让程序员将java对象转换成JSON格式,或者将JSON格式的对象转换成Java对象。

使用方法很简单:

首先,需要将GSON类库的jar包引入到自己的IDE中,本教程使用IDEA为例子。

引入依赖即可,本次不引入依赖,学习一下IDEA怎么引入一个jar包。

1.下载GSON的jar包

GSON的github地址:https://github.com/google/gson/

GSON的下载地址:https://search.maven.org/artifact/com.google.code.gson/gson/2.8.6/jar

在下载地址页面中的右上角点击Downloads,并选择jar。

img

等待下载完毕即可。

2.在IDEA中引入GSON的jar包

在IDEA中创建或者打开一个java项目。

然后右键选择自己的项目,选择New,选择Directory。

img

创建完这个文件夹,给它命名为“lib”。

img

然后将刚刚下载好的jar包移动到lib文件夹中。

img

然后选择File,选择Project Structure。

img

弹出的窗口中选择Libraries,选择“+”,选择Java

img

然后找到并选择之前创建好的lib文件夹,选择OK

img

这里选择Cancel

img

可以看到lib文件夹被添加了进来。

img

然后选择左边菜单中的Modules,选择Dependencies分页,选择“+”,选择Library…

img

选择lib,然后Add Selected

img

然后选择OK

img

至此jar包的引用就完成了。

3.测试是否引入成功

创建一个主类,并添加这个包:“com.google.gson.Gson”。如果没有报错,那么就说明引入成功了。

img

4.使用Gson解析JSON字符串

现在准备工作就已经做完了,接下来是如果使用Gson。

对象 -> JSON字符串

如果想将java对象转换为JSON格式,需要使用Gson对象的toJson方法,方法参数传入需要转换的对象,就会返回字符串形式的JSON。

例如:

public class Main {
    public static void main(String[] args) throws IOException{
 
        //创建一个Person对象
        Person p1 = new Person("小明", 20);
        //创建匿名的Gson对象,并调用toJson方法,传入的参数是想要转换的对象,返回值是转化完毕的json格式字符串。
        String json = new Gson().toJson(p1);
        //打印字符串
        System.out.println(json);
 
    }
}

运行结果:

img

JSON字符串 -> 对象

如果想将JSON字符串转换成java对象,也就是和刚才相反。操作类似,需要使用Gson对象的fromJson的方法,参数1传入需要转换的字符串,参数2传入对象的类型(类名.class)。

public class Main {
    public static void main(String[] args) throws IOException{
 
//      如果需要转换:  {"name":"小明","age":20}
        Person p = new Gson().fromJson("{\"name\":\"小明\",\"age\":20}", Person.class);
        System.out.println(p.getName());
        System.out.println(p.getAge());
 
    }
}

运行结果:

img

另外也可以将Json字符串转换为Map集合,这样就不必为了接受一个JSON对象而写一个类。

例如:

public class Main {    public static void main(String[] args) throws IOException{ //      如果需要转换:  {"name":"小明","age":20}        HashMap map = new Gson().fromJson("{\"name\":\"小明\",\"age\":20}", HashMap.class);        System.out.println("姓名:" + map.get("name"));        System.out.println("年龄:" + map.get("age"));     }}

运行结果:

img

注:下文中的 *** 代表文件名中的组件名称。 # 包含: 中文-英文对照文档:【***-javadoc-API文档-中文(简体)-英语-对照版.zip】 jar包下载地址:【***.jar下载地址(官方地址+国内镜像地址).txt】 Maven依赖:【***.jar Maven依赖信息(可用于项目pom.xml).txt】 Gradle依赖:【***.jar Gradle依赖信息(可用于项目build.gradle).txt】 源代码下载地址:【***-sources.jar下载地址(官方地址+国内镜像地址).txt】 # 本文件关键字: 中文-英文对照文档,中英对照文档,java,jar包,Maven,第三方jar包,组件,开源组件,第三方组件,Gradle,中文API文档,手册,开发手册,使用手册,参考手册 # 使用方法: 解压 【***.jar中文文档.zip】,再解压其中的 【***-javadoc-API文档-中文(简体)版.zip】,双击 【index.html】 文件,即可用浏览器打开、进行查看。 # 特殊说明: ·本文档为人性化翻译,精心制作,请放心使用。 ·本文档为双语同时展示,一行原文、一行译文,可逐行对照,避免了原文/译文来回切换的麻烦; ·有原文可参照,不再担心翻译偏差误导; ·边学技术、边学英语。 ·只翻译了该翻译的内容,如:注释、说明、描述、用法讲解 等; ·不该翻译的内容保持原样,如:类名、方法名、包名、类型、关键字、代码 等。 # 温馨提示: (1)为了防止解压后路径太长导致浏览器无法打开,推荐在解压时选择“解压到当前文件夹”(放心,自带文件夹,文件不会散落一地); (2)有时,一套Java组件会有多个jar,所以在下载前,请仔细阅读本篇描述,以确保这就是你需要的文件;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Archie_java

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值