下载和部署GSON
GSON的GitHub页面地址:https://github.com/google/gson
在使用GSON API工作之前,你需要下载库(jar文件),并将其包含到类路径中。库,连同源代码和Java文档,都可以从http://code.google.com/p/google-gson/downloads/list下载。下载完毕后,添加gson-<version>.jar到类路径。对于那些偏好使用Maven管理依赖(JAR文件)的读者,添加如下依赖到pom.xml。
1
2
3
4
5
|
< dependency > < groupId >com.google.code.gson</ groupId > < artifactId >gson</ artifactId > < version >2.2.4</ version > </ dependency > |
需要修改 <version>2.2.4</version>。本文所有代码示例使用上面列出的版本。pom.xml文件拷贝可以在这里找到。
如果这个库用于web应用,请确保在WEB-INF/lib文件夹中保持一份拷贝。或者,GSON库可以放到应用服务器提供给web应用。
示例
下面是一个简单的例子:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
|
public class Person { private String name; private int age; /** * @return the name */ public String getName() { return name; } /** * @param name the name to set */ public void setName(String name) { this .name = name; } /** * @return the age */ public int getAge() { return age; } /** * @param age the age to set */ public void setAge( int age) { this .age = age; } @Override public String toString() { return name + ":" +age; } } |
实体很简单,两个字段,当然实体中的字段也可以是List或者Set类型的。
1
2
3
4
5
6
7
8
9
|
Gson gson = new Gson(); List<Person> persons = new ArrayList<Person>(); for ( int i = 0 ; i < 10 ; i++) { Person p = new Person(); p.setName( "name" + i); p.setAge(i * 5 ); persons.add(p); } String str = gson.toJson(persons); |
上面的代码重点是Gson对象,它提供了toJason()方法将对象转换成Json字符串,上面代码的str对象值为:
[{"name":"name0","age":0},{"name":"name1","age":5},{"name":"name2","age":10},{"name":"name3","age":15},{"name":"name4","age":20},{"name":"name5","age":25},{"name":"name6","age":30},{"name":"name7","age":35},{"name":"name8","age":40},{"name":"name9","age":45}]
很标准的json数据,很简单吧,呵呵。
下面来看看gson的反序列化,Gson提供了fromJson()方法来实现从Json相关对象到java实体的方法。
在日常应用中,我们一般都会碰到两种情况,转成单一实体对象和转换成对象列表或者其他结构。
先来看第一种:
比如json字符串为:
1
|
[{"name":"name0","age":0}] |
代码:
1
|
Person person = gson.fromJson(str, Person. class ); |
提供两个参数,分别是json字符串以及需要转换对象的类型。
第二种,转换成列表类型:
代码:
1
2
3
4
5
6
|
List<Person> ps = gson.fromJson(str, new TypeToken<List<Person>>(){}.getType()); for ( int i = 0 ; i < ps.size() ; i++) { Person p = ps.get(i); System.out.println(p.toString()); } |
可以看到上面的代码使用了TypeToken,它是gson提供的数据类型转换器,可以支持各种数据集合类型转换。
Gson的基本使用就是这么多,至于annotation方面可以参考gson的官方文档,希望能对初学java和gson的同学有所帮助。