gson自定义Type解析json数组字符串

本文涉及的产品
全局流量管理 GTM,标准版 1个月
云解析 DNS,旗舰版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
简介: gson自定义Type解析json数组字符串


前言

gson解析很好用。

string转对象,可以用

new Gson().fromJson(jsonString,object.class);

对象转String可以使用

String str = gson.toJson(user);

怎么将json数组字符串转成对象list呢?

比如下面的json。嵌套很深。

  • 要转的字符串
[
  {
    "label": "您的驾驶证类型",
    "type": "numberfield",
    "value": "",
    "required": true,
    "order": 2,
    "placeHolder": "",
    "selectOption": [
      {
        "itemValue": "1",
        "itemName": "看书"
      }
    ]
  },
  {
    "label": "您当前驾驶车型",
    "type": "numberfield",
    "value": "",
    "required": true,
    "order": 2,
    "placeHolder": "",
    "selectOption": [
      {
        "itemValue": "1",
        "itemName": "看书"
      }
    ]
  },
  {
    "label": "您当前车辆品牌",
    "type": "numberfield",
    "value": "",
    "required": true,
    "order": 2,
    "placeHolder": "",
    "selectOption": [
      {
        "itemValue": "1",
        "itemName": "看书"
      }
    ]
  },
  {
    "label": "您当前所在省市",
    "type": "numberfield",
    "value": "",
    "required": true,
    "order": 2,
    "placeHolder": "",
    "selectOption": [
      {
      "itemValue": "1",
      "itemName": "看书"
      }
    ]
  }
,
  {
    "label": "海选赛举办城市",
    "type": "numberfield",
    "value": "",
    "required": true,
    "order": 2,
    "placeHolder": "",
    "selectOption": [
      {
        "itemValue": "1",
        "itemName": "看书"
      }
    ]
  }
]

答: 自定义TypeToken

实战

  • 实体类
    CustomFieldDTO
/**
 * 活动自定义字段
 */
@NoArgsConstructor
@Data
public class CustomFieldDTO {
    @JsonProperty("label")
    private String label;
    @JsonProperty("type")
    private String type;
    @JsonProperty("value")
    private String value;
    @JsonProperty("required")
    private Boolean required;
    @JsonProperty("order")
    private Integer order;
    @JsonProperty("placeHolder")
    private String placeHolder;
    @JsonProperty("selectOption")
    private List<SelectOptionDTO> selectOption;
    @NoArgsConstructor
    @Data
    public static class SelectOptionDTO {
        @JsonProperty("itemValue")
        private String itemValue;
        @JsonProperty("itemName")
        private String itemName;
    }
}
  • 自定义typeToken转换
@Test
    public void testPrintMessage() {
        Gson gson = new Gson();
        //转成json数组
        //自定义类型转换
        Type type = new TypeToken<List<CustomFieldDTO>>() { }.getType();
        //解析
        List<CustomFieldDTO> list = gson.fromJson(str, type);
        //遍历打印
        list.parallelStream().forEach((item) -> {
            logger.info(String.valueOf(item));
        });
    }
  • 效果

    看出解析出结果了。
    代码很优雅,不用一个字段一个字段的处理。推荐!!!

相关文章
|
3月前
|
SQL 存储 JSON
SQL,解析 json
SQL,解析 json
89 8
|
1天前
|
JSON 前端开发 搜索推荐
关于商品详情 API 接口 JSON 格式返回数据解析的示例
本文介绍商品详情API接口返回的JSON数据解析。最外层为`product`对象,包含商品基本信息(如id、name、price)、分类信息(category)、图片(images)、属性(attributes)、用户评价(reviews)、库存(stock)和卖家信息(seller)。每个字段详细描述了商品的不同方面,帮助开发者准确提取和展示数据。具体结构和字段含义需结合实际业务需求和API文档理解。
|
4月前
|
JavaScript
js 解析 byte数组 成字符串
js 解析 byte数组 成字符串
103 5
|
14天前
|
JSON JavaScript 前端开发
一次采集JSON解析错误的修复
两段采集来的JSON格式数据存在格式问题,直接使用PHP的`json_decode`会报错。解决思路包括:1) 手动格式化并逐行排查错误;2) 使用PHP-V8JS扩展在JavaScript环境中解析。具体方案一是通过正则表达式和字符串替换修复格式,方案二是利用V8Js引擎执行JS代码并返回JSON字符串,最终实现正确解析。 简介: 两段采集的JSON数据因掺杂JavaScript代码导致PHP解析失败。解决方案包括手动格式化修复和使用PHP-V8JS扩展在JavaScript环境中解析,确保JSON数据能被正确处理。
|
3月前
|
JSON 前端开发 JavaScript
json字符串如何转为list对象?
json字符串如何转为list对象?
474 7
|
4月前
|
JSON 前端开发 JavaScript
解析JSON文件
解析JSON文件
170 9
|
4月前
|
JSON API 数据格式
requests库中json参数与data参数使用方法的深入解析
选择 `data`或 `json`取决于你的具体需求,以及服务器端期望接收的数据格式。
332 2
|
3月前
|
JSON JavaScript API
商品详情数据接口解析返回的JSON数据(API接口整套流程)
商品详情数据接口解析返回的JSON数据是API接口使用中的一个重要环节,它涉及从发送请求到接收并处理响应的整个流程。以下是一个完整的API接口使用流程,包括如何解析返回的JSON数据:
|
4月前
|
XML JSON 前端开发
json字符串CSS格式化
json字符串CSS格式化
81 5
|
4月前
|
JSON 数据格式 Python
6-1|Python如何将json转化为字符串写到文件内 还保留json格式
6-1|Python如何将json转化为字符串写到文件内 还保留json格式

热门文章

最新文章

推荐镜像

更多