Javaの《JSON解析》课堂学习笔记

一 JSON简介

JSON (JavaScript Object Notation)JS对象简谱,是一种轻量级的数据交换格式。目前Java官方并没有内置解析JSON的工具,需要自行安装解析工具,流行的有GsonFastJson

1,格式

由一个大括号表示,括号中描述对象的属性。通过键值对来描述对象的属性。
键与值之间使用冒号连接,多个键值对之间使用逗号分隔

XML:
 <book>
     <name>金苹果</name>
     <info>种苹果</info>
 </book>
 
 JSON:
 {
    "name":"金苹果",
    "info":"种苹果"
 }

2,嵌套

在JSON格式中,对象等可以互相嵌套:[元素1,元素2…]

{
        "name":"伟杰老师",
        "age":18,
        "pengyou":["张三","李四","王二","麻子",{
              "name":"野马老师",
              "info":"像匹野马一样狂奔在技术钻研的道路上"
           }],
        "heihei":{
          "name":"大长刀",
          "length":"40m"
       }
     }

// 对象里套对象,对象里套数组,数组里套对象 ···
// pengyou 0下标是张三,4下标是一个对象(嵌套,包含了name和info)。

解析嵌套层级:https://www.sojson.com/ → JSON视图 → 解析JSON

二 JSON解析

0,步骤

第一步:引入Jar包

(1)最外层文件夹,New → Directory  →  命名为lib

(2)找到jar文件,复制粘贴到lib下

(3)菜单栏 File → Project Structrue → libraries → 添加+   Java  
                    → 项目名下src文件, OK → 取消cancel Choose Modules

(4)设置相应的库:最右侧栏 移除- Source  → 添加+ lib文件夹中的jar文件 → Apply

(5)Modules → Dependencies →  添加+ library →  src(库名叫src) → Apply

(6)导入成功:Project的lib文件夹中,各jar文件展开有效

第二步:创建对象

第三步:转换:在需要转换的位置写代码。

以下案例类 class Book:

public class Book {
    private String id;
    private String name;
    private String info;
    // toString、equals、hashCode、get、set、全参、无参略
}

1,Gson

(1)Java对象转为JSON字符串

在需要转换JSON字符串的位置编写如下代码:

String json = new Gson().toJSON(要转换的对象);

Gson g = new Gson();
Book b = new Book("100","金苹果","种植苹果真辛苦");
String s = g.toJson(b);
System.out.println(s);

简化:

Book b = new Book("100","金苹果","种植苹果真辛苦");
String s = new Gson().toJson(b);
System.out.println(s);

输出结果:{“id”:“100”,“name”:“金苹果”,“info”:“种植苹果真辛苦”}

(2)JSON字符串转为Java对象

在需要转换Java对象的位置, 编写如下代码:

对象 = new Gson().fromJson(JSON字符串,对象类型.class);

Gson g = new Gson();

Book b = g.fromJson(
        "{\"id\":\"100\",\"name\":\"金苹果\",\"info\":\"种植苹果真辛苦\"}", Book.class);

System.out.println(b.getId()+" "+b.getName()+" "+b.getInfo());
System.out.println(b);

输出结果:

100 金苹果 种植苹果真辛苦
Book{id=‘100’, name=‘金苹果’, info=‘种植苹果真辛苦’}

(3)JSON字符串转为Java数组

 Gson g = new Gson();
 HashMap data = g.fromJson(
                "{\"id\":\"100\",\"name\":\"金苹果\",\"info\":\"种植苹果真辛苦\",\""+
                "page\":[\"锄禾日当午\",\"汗滴禾下土\",\"谁知盘中餐\"]}", HashMap.class);
 
 System.out.println(data.get("page"));
 System.out.println(data.get("page").getClass()); //不是数组
 
 List page = (List) data.get("page");
 System.out.println(page.get(1));

输出结果:

[锄禾日当午, 汗滴禾下土, 嘿嘿嘿嘿嘿]
class java.util.ArrayList
汗滴禾下土

2,FastJson

(1)Java对象转为JSON字符串

在需要转换JSON字符串的位置编写如下代码:

String json=JSON.toJSONString(要转换的对象);

Book book = new Book("1002","唐诗三百首","床前明月光");

String json = JSON.toJSONString(book);
System.out.println(json);

输出结果:{“id”:“1002”,“info”:“床前明月光”,“name”:“唐诗三百首”}

(2)JSON字符串转为Java对象

在需要转换Java对象的位置, 编写如下代码:

转对象:类型 对象名=JSON.parseObject(JSON字符串, 类型.class);

Book b = JSON.parseObject(
          "{\"id\":\"1002\",\"info\":\"床前明月光\",\"name\":\"唐诗三百首\"}", Book.class);

System.out.println(b.getId()+" "+b.getName()+" "+b.getInfo());
System.out.println(b);

输出结果:

1002 唐诗三百首 床前明月光
Book{id=‘1002’, name=‘唐诗三百首’, info=‘床前明月光’}

(3)JSON字符串转为Java数组

转数组:List<类型> list=JSON.parseArray(JSON字符串,类型.class);

List<String> strings = 
JSON.parseArray("[\"一二三\",\"二三四\",\"三四五\"]", String.class);

System.out.println(strings.get(1));

输出结果:二三四

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java,你可以使用MySQL Connector/J库来连接和操作MySQL数据库。然后,你可以使用JSON库(如Jackson或Gson)来解析JSON数据。 首先,确保已经导入了MySQL Connector/J和JSON库的相关依赖。然后,你可以按照以下步骤进行JSON解析: 1. 导入所需的: ```java import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.Statement; import com.fasterxml.jackson.databind.ObjectMapper; // 如果使用Jackson库 // 或者 import com.google.gson.Gson; // 如果使用Gson库 ``` 2. 建立与MySQL数据库的连接: ```java String url = "jdbc:mysql://localhost:3306/your_database"; String username = "your_username"; String password = "your_password"; Connection connection = DriverManager.getConnection(url, username, password); ``` 3. 执行SQL查询并获取结果集: ```java Statement statement = connection.createStatement(); String sql = "SELECT * FROM your_table"; ResultSet resultSet = statement.executeQuery(sql); ``` 4. 遍历结果集并解析JSON数据: ```java while (resultSet.next()) { String json = resultSet.getString("json_column"); // 假设JSON数据存储在名为"json_column"的列 // 使用Jackson库解析JSON ObjectMapper objectMapper = new ObjectMapper(); YourObject yourObject = objectMapper.readValue(json, YourObject.class); // 或者使用Gson解析JSON Gson gson = new Gson(); YourObject yourObject = gson.fromJson(json, YourObject.class); // 对解析得到的对象进行操作 // ... } ``` 其,YourObject是你定义的与JSON数据结构相匹配的Java对象。 请根据实际情况替换相关的数据库连接参数、SQL查询以及JSON解析部分的代码。希望对你有帮助!如果你还有其他问题,请随时提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值