Android json数据解析之Gson和FastJson的应用

一:Gson应用

Gson是谷歌提供的一个开源库,能够用来解析JSON数据。
1.什么是json
json就是用来进行网络数据传输的一种格局,目前的应用很宽泛,其格局就是一种键值对的模式,很不便进行解析。json有Json对象(JsonObject)和Json数组(JsonArray)两种模式。但凡以{}就是一个Json对象,但凡[]就是一个Json数组。

{//一个Json对象 "user": "user1",  "pwd": "123456"}
{//这个对象有4个字段,其中一个是数组  "user": "user1",   "pwd": "123456",   "jsonArray": [//一个Json数组外面有2个Json对象,每个Json对象有2个字段             {"user": "user1",               "pwd": "123456"},                    {"user": "user2",              "pwd": "123456"}                        ],   "result": "胜利"            }

2.增加Gson依赖
这是github上19.1kStar我的项目

在app下build.gradle增加依赖
implementation 'com.google.code.gson:gson:2.8.6'
3.应用GsonFormat工具
Gson是采纳对象映射的形式,所有要为JSON数据创立一个Java对象来与之对应。
1.装置GsonFormat插件
2.新建一个类,在类外面按Alt+S键,并将要转换的Json数据复制进去
4.Gson应用

public class User implements Serializable {    /** * user : user1 * pwd : 123456 * jsonArray : [{"user":"user1","pwd":"123456"},{"user":"user2","pwd":"123456"}] * result : 胜利 */ private String user; private String pwd; private String result; private List<JsonArrayBean> jsonArray; public static class JsonArrayBean implements Serializable {        /** * user : user1 * pwd : 123456 */ private String user; private String pwd; public String getUser() {            return user; }        public void setUser(String user) {            this.user = user; }        public String getPwd() {            return pwd; }        public void setPwd(String pwd) {            this.pwd = pwd; }    }    public String getUser() {        return user; }    public void setUser(String user) {        this.user = user; }    public String getPwd() {        return pwd; }    public void setPwd(String pwd) {        this.pwd = pwd; }    public String getResult() {        return result; }    public void setResult(String result) {        this.result = result; }    public List<JsonArrayBean> getJsonArray() {        return jsonArray; }    public void setJsonArray(List<JsonArrayBean> jsonArray) {        this.jsonArray = jsonArray; }}

解析JSON对象

String jsonData="要解析的Json字符串";Gson gson=new Gson();User user=gson.fromJson(jsonData, User.class);String result=user.getResult();Log.d("aa",result);===========aa: 胜利

解析Json对象外面的数组

  // 因为jsonArray字段对应的是一个JSON数组,所以要用一个List来对应List<User.JsonArrayBean> jsonArrayBeans=user.getJsonArray();//取值for (int i=0;i<jsonArrayBeans.size();i++){  User.JsonArrayBean jsonArrayBean=jsonArrayBeans.get(i); String u=jsonArrayBean.getUser(); Log.d("bb",u); ================ 取到的值bb: user1bb: user2

解析纯数组

[    {"user": "user8",      "pwd": "123456"},            {"user": "user9",      "pwd": "123456"}]//应用形式Gson gson=new Gson();List<Data> datas=gson.fromJson(jsonData, new TypeToken<ArrayList<Data>>(){}.getType());for (int i=0;i<datas.size();i++){  Data data=datas.get(i); String u=data.getUser(); Log.d("cc",u);}//打印后果cc: user8cc: user9

序列化对象成Json(Teacher对象下4个属性 age,email,isDeveloper,name)

Gson gson=new Gson();Teacher teacher=new Teacher("Rocky","111@qq.com",22,true);String teacherJson=gson.toJson(teacher);Log.d("bb",teacherJson);打印后果 bb {"age":22,"email":"111@qq.com","isDeveloper":true,"name":"Rocky"}

如果变量为空值的话序列化和反序列化
1.可见某个变量为null时,Gson在序列化的时候间接把这个变量疏忽了
2.对于JSON字符串里没有的变量,Gson在反序列化时会给它一个默认值,int类型默认为0,bool类型默认为false,String类型默认为null

Gson gson=new Gson();Teacher teacher=new Teacher("Rocky",null,22,true);String teacherJson=gson.toJson(teacher);Log.d("bb",teacherJson);


管制序列化/反序列化的变量名称
以Teacher对象为例,如果JSON字符串的变量名name变成fullName,无需缓和,咱们也不必把Teacher对象的变量name改成fullName,而后把get,set办法全改了。只须要用Gson提供的注解@SerializedName就行。

public class Teacher{@SerializedName("fullName")//@SerializedName(value = "name", alternate = "fullName")//然而事实远比设想中简单,这个JSON有时候传的是`fullName`,有时候传的是`name`,这时该怎么办呢? 不必放心,`@SerializedName` 承受两个参数,`value` 和 `alternate` ,顾名思义,`alternate` 是备选变量名private String name;private String email;private int age;private boolean isDeveloper;}打印Json后果{"age":22,"isDeveloper":true,"fullName":"Rocky"}

序列化/反序列化过程中疏忽某些变量

public class Teacher  {    @SerializedName("fullName")    private String name; private String email; //@Expose()参加序列化和反序列化 //@Expose(serialize = false)不参加序列化,只参加反序列化 // @Expose(deserialize = false)只参加序列化,不参加反序列化 @Expose(serialize = false,deserialize = false)//序列化和反序列化都不参加 private int age; private boolean isDeveloper; }

然而:要应用这个注解来管制序列化和反序列化,就不能应用默认的Gson对象

//Gson gson=new Gson();不能通过这种形式构建Gson对象GsonBuilder builder=new GsonBuilder();builder.excludeFieldsWithoutExposeAnnotation();//builder.setPrettyPrinting();Gson gson=builder.create();Teacher teacher=new Teacher("Rocky","11@qq.com",22,true);String teacherJson=gson.toJson(teacher);Log.d("bb",teacherJson);打印后果bb: {}  我不晓得为什么这种形式呈现的后果是空,按理说我只是限定一个属性的序列化形式依照网上说的形式构建的Gson也不能我把builder.excludeFieldsWithoutExposeAnnotation();换成builder.setPrettyPrinting();能够打印进去然而没有限度字段的序列化和反序列化形式二:transient字段 通过private transient int age;   Gson gson=new Gson(); Teacher teacher=new Teacher("Rocky","11@qq.com",22,true); String teacherJson=gson.toJson(teacher); Log.d("bb",teacherJson); 打印后果{"email":"11@qq.com","isDeveloper":true,"fullName":"Rocky"}

二:FastJson应用
FastJson是一个Java语言的编写的高性能的Json处理器,由阿里巴巴公司开发的,github上23kStar

1.增加依赖
implementation 'com.alibaba:fastjson:1.2.73'
2.序列化Json,把对象转成Json串调用JSON.toJSONString

tudent student=new Student("Mike",12);String studentJson =JSON.toJSONString(student,true);//为true就是要格式化Json,flase就是非格式化Json//Gson的builder.setPrettyPrinting();格式化JsonLog.d("aa",studentJson);打印后果:aa: {        "age":12,        "name":"Mike"    }

3.反序列化Json,把Json串转成对象JSON.parseObject

String json = "{"age":18, "name":"Rocky"}";Student student=JSON.parseObject(json,Student.class);//要记得Student 增加一个无参的构造方法Log.d("bb",student.getName());Log.d("bb",student.getAge()+"");打印后果bb: Rockybb: 18

如果没有无参的构造方法会报谬误

Json转成简单的Bean,如List ,Set,Map

public class Student { private String name; private int age; ....疏忽get,set办法 }一:List形式String json = "[{"age":18, "name":"Rocky"},{"age":19, "name":"jack"}]";List<Student> lists=JSON.parseObject(json,new TypeReference<ArrayList<Student>>(){});for (int i=0;i<lists.size();i++){    Student student=lists.get(i); Log.d("cc",student.getName()); Log.d("cc",student.getAge()+"");}二:Set形式String json = "[{"age":18, "name":"Rocky"},{"age":19, "name":"jack"}]";Set<Student> lists=JSON.parseObject(json,new TypeReference<HashSet<Student>>(){});for (Student student:lists){    Log.d("cc",student.getName()); Log.d("cc",student.getAge()+"");}打印后果cc: Rockycc: 18cc: jackcc: 19

@JSONField注解的应用
1.作用于get办法上:当把注解作用于get办法上的时候,在把Java对象转化成Json字符串的时候,Java对象中的字段名会转化为注解中的name指定的字段名。

@JSONField(name = "myAge")public int getAge() {    return age;}Student student=new Student();student.setAge(15);student.setName("Rock");String studentJson =JSON.toJSONString(student,true);Log.d("aa",studentJson);打印后果aa: {        "myAge":15,//变成咱们正文的属性名        "name":"Rock"    }

2 作用于set办法上:在把json字符串转化成java对象的时候,注解中的name指定的字段名会映射为Java对象中的字段名。

@JSONField(name = "myName")public void setName(String name) {    this.name = name;} String json = "{"age":2,"myName":"ss"}";//这个Json串的属性换成标记的Student student= JSON.parseObject(json,Student.class); Log.d("cc",student.getName()); Log.d("cc",student.getAge()+"");  打印后果 cc: ss cc: 2

3 @JSONField作用于java类的字段上

public class Student {    @JSONField(name = "name", alternateNames = {"myName", "meName"})    private String name; private int age; }   String json = "{"age":2,"meName":"ss"}";//这个name字段能够是myName,也能够是meName都能够映射到name字段上Student student= JSON.parseObject(json,Student.class); Log.d("cc",student.getName()); Log.d("cc",student.getAge()+"");  打印后果 cc: ss cc: 2

Java Bean对象与JSONObject 对象互相转换
Java Bean对象--->JSONObject对象--->json字符串

 student.setAge(15); student.setName("Rock"); JSONObject jsonObject= (JSONObject) JSON.toJSON(student);//JSONObject对象 String studentJson= jsonObject.toJSONString();//转成Json字符串,toString()也能够 Log.d("aa",studentJson);

json字符串与JSONObject对象转换
json字符串--->JSONObject对象

String json = "{"age":2,"meName":"ss"}";JSONObject studentObject= JSON.parseObject(json);

json字符串转成Java汇合能够间接应用JSON.parseArray()

String json = "[{"age":18, "name":"Rocky"},{"age":19, "name":"jack"}]";List<Student> lists=JSON.parseArray(json,Student.class);for (Student student:lists){    Log.d("cc",student.getName()); Log.d("cc",student.getAge()+"");}

END:所求皆吾愿,所行化坦途