gson对象封装解析

gson解析给大家打开很多便利,封装起来也比较省事,简单的gson解析直接用class或者type解析出来就可以了。
不过一般的服务端返回用户对象封装好多会遇到各种问题各种坑

以下分析常用的gson解析服务器返回的通用方法:

1、客户端和服务器一般gson格式都会定义固定的格式方便接口统一处理
比如类似下边的格式,data可以是array 数组[],也可以是obj{}

{
    "code": "0000",
    "msg": "成功",
    "t": [{
        "userid": "1",
        "userName": "张三"
    }, {
        "userid": "1",
        "userName": "王五"
    }]
}
{
    "code": "0000",
    "msg": "成功",
    "data": {
        "userid": "1",
        "userName": "张三"
    }
}

2、解析这样的数据,一般大家都会把data 分开解析,如果是数组的话怎么解析,如果是对象的话怎么解析。具体这种解析可以看相关的文档。
分开解析可以满足需求,但是对于解析过程多了一步,先解析完成第一级才能判断是否数组,这样效率有所影响
3、其实可以利用泛型及泛型的的一个方法来获取解析的数据类型的
首先我们先一个基础对象封装类

abstract class  JsonModels<T>  {



    private String msg;
    private String code;
    private T data;

     
    public String getMsg() {
        return msg;
    }
    public T getData() {
        return data;
    }

    public void setData(T data) {
        this.data = data;
    }

    public void setMsg(String msg) {
        this.msg = msg;
    }

    public String getCode() {
        return code;
    }

    public void setCode(String code) {
        this.code = code;
    }

     
     
    
    
}

我们再根据下边的方法获取到t,t其实就是所传到对象的User或者是List<User>;

Type type = getClass().getGenericSuperclass();
Type[] t = ((ParameterizedType) type).getActualTypeArguments();

获取到t后我们怎么拼装成Type呢?查看源码发现Type有几个实现类我们用到ParameterizedType,然后继承这个类之后把jmodel和t设置进去就可以了

class ParameterizedTypeImpl implements ParameterizedType {
    Type[] type;
    Class raw;

    @Override
    public Type[] getActualTypeArguments() {
        // TODO 自动生成的方法存根
        return type;
    }

    @Override
    public Type getOwnerType() {
        // TODO 自动生成的方法存根
        return null;
    }

    public ParameterizedTypeImpl(Type[] args, Class raw) {
        super();
        this.type = args != null ? args : new Type[0];
        this.raw = raw;
    }

    @Override
    public Type getRawType() {
        // TODO 自动生成的方法存根
        return raw;
    }

我们可以直接把json解析放到JsonModel中去

public JsonModel<T> toJsonModel(String json) {
        Type type = getClass().getGenericSuperclass();
        Type[] t = ((ParameterizedType) type).getActualTypeArguments();
        Type ty = new ParameterizedTypeImpl(t, JsonModel.class);
        return new Gson().fromJson(json, ty );
    }

----注意这个方法getGenericSuperclass调用必须是JsonModels为抽象类,我们再写一个实现类,实现类可以为空什么也不写,如下:

class JsonModel<T> extends JsonModels<T>{}

现在基本类已经写完了,以下就是直接调用了。

    public static void main(String args[]) {
//      String json="{\"code\":\"0000\",\"msg\":\"成功\",\"data\":[{\"userid\":\"1\",\"userName\":\"张三\"},{\"userid\":\"1\",\"userName\":\"王五\"}]}";
        String json="{\"code\":\"0000\",\"msg\":\"成功\",\"data\":{\"userid\":\"1\",\"userName\":\"张三\"}}";
        JsonModel<List<User>> j=new  JsonModel<List<User>>().toJsonModel(json);
        
        System.out.println(j.getData());
    }

调用的时候是不是很简单呢,基本的解析就到这里了,其实封装的关键主要是运用了如下几个特性
getGenericSuperclass,ParameterizedType

GitHub已经上传完整代码欢迎大家下载

https://github.com/wbsh583/gsonutl

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 1.概述2.Gson的目标3.Gson的性能和扩展性4.Gson的使用者5.如何使用Gson 通过Maven来使用...
    人失格阅读 14,344评论 2 18
  • JSON的特点: 1、JSON比XML的数据传递的有效性高;2、JSON完全独立于编程语言;3、JSON的本质是具...
    程序员之路阅读 3,545评论 0 3
  • 做网络请求的时候肯定要封装回调,我这里就传了泛型,但是出了个问题是Gson没办法直接解析泛型,如果直接解析的话,不...
    键盘上的麒麟臂阅读 32,771评论 9 26
  • 价格歧视的策略。 价格歧视其实非常有意义,能够促进生产,减少浪费,最大化增加消费者满足感的商业行为,但也是一种被深...
    瞰川阅读 402评论 0 0
  • 很小的时候,我就期盼着赶紧长大,长大了就可以像姐姐们一样玩耍,长大了就没有父母的唠叨,长大了就有了自由。 ...
    水筠心宁阅读 172评论 0 0