JSONObject解析json为指定泛型对象

有这样一个json,有没有什么办法将它一行代码转换为想要的结构:Map<String, User>?在这里插入图片描述

答案是肯定的,借助alibaba的fastjson即可。代码如下:

package com.powerengine.demo;

import com.alibaba.fastjson.JSONObject;
import com.alibaba.fastjson.TypeReference;
import org.junit.Test;

import java.util.HashMap;

/**
 * @author dongPo
 * Date  2022/9/5
 * Desc
 */
public class JsonTest {
    @Test
    public void t1() {
        String json = "{\n" +
                "    \"lisa\":{\n" +
                "        \"roleIds\":[\n" +
                "            \"1\",\n" +
                "            \"2\"\n" +
                "        ],\n" +
                "        \"name\":\"lisa\",\n" +
                "        \"pwd\":\"111\"\n" +
                "    },\n" +
                "    \"jack\":{\n" +
                "        \"roleIds\":[\n" +
                "            \"3\",\n" +
                "            \"4\"\n" +
                "        ],\n" +
                "        \"name\":\"jack\",\n" +
                "        \"pwd\":\"222\"\n" +
                "    }\n" +
                "}";
        // TypeReference 的包为 import com.alibaba.fastjson.TypeReference;
        HashMap<String, User> userMap = JSONObject.parseObject(json, new TypeReference<HashMap<String, User>>() {});
        System.out.println(userMap.get("lisa").name);
    }
}

最重要的一句:

JSONObject.parseObject(json, new TypeReference<HashMap<String, User>>() {});
// 注意最后的花括号不能少,TypeReference中的泛型就是要转换的自定义的类型

User对象如下:

package com.powerengine.demo;

import java.io.Serializable;

/**
 * @author dongPo
 * Date  2022/9/6
 * Desc
 */
public class User implements Serializable {
    private static final long serialVersionUID = -949663088546640229L;

    String name;
    transient String pwd;
    String[] roleIds;


    public String getName() {
        return name;
    }

    public String getPwd() {
        return pwd;
    }

    public String[] getRoleIds() {
        return roleIds;
    }

    public void setName(String name) {
        this.name = name;
    }

    public void setPwd(String pwd) {
        this.pwd = pwd;
    }

    public void setRoleIds(String[] roleIds) {
        this.roleIds = roleIds;
    }

    public User() {
    }
}

有了这个方法,就能省很多事了,不需要自己再去解析JSONObject,一步到位。

03-21
### 关于 Mycat 数据库中间件 #### 什么是 Mycat? Mycat 是一款开源的分布式数据库系统,作为数据库中间件,主要用于解决大数据场景下的读写分离、分库分表等问题[^5]。它可以像 MySQL 一样被使用,开发者只需在 Mycat 中配置具体的分库分表策略即可完成复杂的数据管理任务[^1]。 #### Mycat 的主要功能特性 Mycat 提供了一系列强大的功能来提升数据库性能和可扩展性: - **分布式架构**:支持分片(Sharding)、读写分离,从而显著提高数据库处理能力和并发量。 - **高可用性**:具备主备切换以及故障自动恢复的能力,保障系统的稳定运行。 - **动态数据路由**:能够根据实际业务需求灵活调整分片策略,满足不同应用场景的需求。 - **多协议兼容**:除了支持 MySQL 外,还兼容 MariaDB、Oracle 和 SQL Server 等多种数据库系统[^3]。 #### 安装与环境准备 为了成功部署并使用 Mycat,需按照以下指导进行操作: 1. 准备好 Java 运行环境(JDK 版本建议为 1.8 或更高版本),因为 Mycat 基于 Java 编写而成[^2]。 2. 下载官方发布的最新版 Mycat 软件包,并解压至目标目录下。 3. 修改 `server.xml` 文件中的相关参数设置,比如监听端口号,默认情况下为 `8066`;同时定义逻辑数据库名称及其对应的物理节点信息。 4. 启动服务进程并通过命令行工具或者图形界面访问验证连接状态正常与否。 #### 查询示例 当一切就绪之后,在日常开发过程中可以通过如下方式发起简单的查询请求: ```sql SELECT * FROM user; ``` 此条语句会经由 Mycat 解析后转发给相应的后台存储引擎执行完毕再返回结果集给前端调用方[^4]。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值