原文地址: http://blog.52sox.com/use-gso...
关于为何忽然会使用Java,实际上仍是公司要将以前原先Python开发的Elasticsearch搜索集成到到项目中,而必须在国庆前给出1个版本。真心的说,进度很赶,对于一个平时不怎么写Java的Pythoner来讲,花了1天的时间把对应的功能完成的70%,不得不说是1个奇迹。
在Jest包中,有这么1个Gson的包,用于对JSON数据进行序列化处理。这里咱们单独将其拿出来,稍微简单的介绍一下,之后遇到一样的问题的时候也不用慌。这里使用的gson版本为2.8.0
。
咱们使用maven下载了对应的包后,首先进行以下的操做:html
import com.google.gson.*;
接着咱们实例化Gson类,并调用其toJson方法对1个对象进行序列化处理:前端
import java.util.*; ... public class demo { public static void main(String[] args){ Gson json = new Gson(); HashMap<String,Object> map = new HashMap<>(); ArrayList<String> arr = new ArrayList<>(); arr.add("张三"); arr.add("李四"); map.put("person", arr); String str = json.toJson(map); System.out.println(str); } }
其结果以下所示:java
{"person":["张三","李四"]}
能够说是1个很是简单的例子。可是上面的方式,对于数值为null的状况会忽略掉对应的键名,以下所示:json
HashMap<String,Object> map = new HashMap<>(); ArrayList<String> arr = new ArrayList<>(); arr.add("张三"); arr.add("李四"); map.put("person", arr); map.put("gender", null); String str = json.toJson(map);
其结果为:maven
{"person":["张三","李四"]}
此时咱们可使用以下的方式进行序列化:ide
GsonBuilder json = new GsonBuilder(); String str = json.serializeNulls().create().toJson(map);
另外,默认的序列化是没有美化效果的,看起来不是很方便,此时咱们能够添加setPrettyPrinting
方法来设置其为美化的输出:函数
String str = json.serializeNulls().setPrettyPrinting().create().toJson(map);
相应的结果当即就变成了:ui
{ "gender": null, "person": [ "张三", "李四" ] }
除此以外,咱们还能够对类进行实例化,好比咱们有以下1个简单的类:google
class Person { private String name = "张三"; private int age = 23; private String gender = "男"; @Override public String toString(){ return name + ":" + age + ":" + gender; } }
接着咱们再进行实例化处理:.net
Person person = new Person(); String str = json.toJson(person); System.out.println(str);
其结果为:
{"name":"张三","age":23,"gender":"男"}
能够看到,对应类的属性都被实例化了。另外,在这里咱们对类的toString进行了重载,也是1种序列化的方式。
另1个比较有意思的地方,可能就是使用注解的方式来进行序列化处理了,例如:
import com.google.gson.annotations.*; class Person { @SerializedName("username") @Expose(serialize = true) private String name = "张三"; private int age = 23; @Expose(serialize = true) private String gender = "男"; } ... Person person = new Person(); String str2 = json.serializeNulls().excludeFieldsWithoutExposeAnnotation().create().toJson(person); System.out.println(str2);
在这里咱们只序列化name和gender这个2个属性,其中属性name序列化时候的名称为username,以后咱们调用GsonBuilder进行处理能够获得:
{"username":"张三","gender":"男"}
而对于反序列化处理,咱们只须要使用fromJson
函数便可,例如咱们能够对以前的JSON数据进行反序列化处理:
Person info = json.create().fromJson(str2, Person.class); System.out.println(info);
因为咱们以前重载了对应类的toString方法,所以其结果为:
张三:23:男
另1个就是对以前新建的HashMap进行反序列化处理:
HashMap<?, ?> dict = json.create().fromJson(str, HashMap.class); System.out.println(dict);
其结果为:
{gender=null, person=[张三, 李四]}
经过反序列化,在调用Jest时对于返回的数据,咱们就能够进行筛选,去除一些不须要的内容再序列化返回到前端。
而Gson还有一些其余的内容,好比对指定类型的序列化处理,这里就不叙述了,能够参考。
参考文章:
http://www.javadoc.io/doc/com...
https://www.cnblogs.com/mafly...
https://www.cnblogs.com/majay...