1. json数据类型
-
json中不区分整数、小数等类型,而统一使用Number来存储数字。
-
Array表示数组,以中括号"[]"括起来,元素之间以逗号分隔,元素可以为任意类型。
-
Object表示对象,类似于C语言中的结构体,以花括号"{}"括起来,其元素要求为键值对,key必须为String类型的,而value则可为任意类型。key和value之间以":"表示映射关系,元素之间也是以逗号分隔。
2. 构建json
在idea中使用JSONObject需要引用 org.json 包,推荐通过maven引用。
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<!--pom.xml使用的对象模型版本-->
<modelVersion>4.0.0</modelVersion>
<!--项目名称,一般写项目的域名-->
<groupId>cn.xiwh</groupId>
<!--模块名称,子项目名或模块名称-->
<artifactId>testProj</artifactId>
<!--产品的版本号-->
<version>1.0-SNAPSHOT</version>
<!-- 项目的描述名 -->
<name>myjson</name>
<!-- 项目的地址 -->
<url>http://maven.apache.org</url>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>
<!--项目依赖构件配置,配置项目依赖构件的坐标-->
<dependencies>
<!--加入对org.json的依赖-->
<dependency>
<groupId>org.codeartisans</groupId>
<artifactId>org.json</artifactId>
<version>20161124</version>
</dependency>
<!--加入对commons-io的依赖-->
<dependency>
<groupId>commons-io</groupId>
<artifactId>commons-io</artifactId>
<version>2.4</version>
</dependency>
<!-- 单元测试 -->
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.12</version>
</dependency>
</dependencies>
</project>
2.1 直接构建
直接构建即直接实例化一个JSONObject对象,而后调用其put()方法,将数据写入。put()方法的第一个参数为key值,必须为String类型,第二个参数为value,可以为boolean、double、int、long、Object、Map以及Collection等。当然,double以及int等类型只是在Java中,写入到json中时,统一都会以Number类型存储。
JSONObject obj = new JSONObject();
obj.put(key, value);
范例:
package cn.xiwh.test;
import org.json.JSONObject;
import org.junit.Test;
public class JSONTest {
@Test
public void buildJson() {
//调用toString()方法可直接将其内容打印出来
System.out.println(createJson().toString());
}
private static JSONObject createJson() {
JSONObject object = new JSONObject();
object.put("name", "Jack");
object.put("age", 26);
object.put("sex", "male");
object.put("isStudent", false);
object.put("hobbies", new String[]{"音乐", "打篮球"});
return object;
}
}
输出结果为:
{"isStudent":false,"sex":"male","age":26,"name":"Jack","hobbies":["音乐","打篮球"]}
这里可以看到,为了压缩大小以便于更高效地传输,json把所有空格、换行符等空白符全部去掉了。如果想要直观点看其内容,可以用一些在线的json解析器看。
例如:http://www.jsoneditoronline.org/ 或者 https://tool.oschina.net/codeformat/json/
2.2 使用HashMap构建
使用HashMap构建json,实际上即先创建好一个HashMap对象并且将数据打包进去,而后在创建JSONObject时将其作为一个参数传进去。
范例:
package cn.xiwh.test;
import org.json.JSONObject;
import org.junit.Test;
import java.util.HashMap;
import java.util.Map;
public class JSONTest {
@Test
public void mapBuildJson() {
System.out.println(createJsonByMap().toString());
}
private static JSONObject createJsonByMap() {
Map<String, Object> map = new HashMap<String, Object>();
map.put("name", "Tom");
map.put("age", 23);
map.put("sex", "male");
map.put("isStudent", true);
map.put("hobbies", new String[]{"登上", "读书"});
JSONObject obj = new JSONObject(map);
return obj;
}
}
2.3 使用JavaBean构建
相较于前两种方法,实际开发中应用JavaBean构建 json 的情况更为常见,因为这样代码的重用率更高。
范例:
JavaBean:
package cn.xiwh.bean;
public class PersonInfo {
private String name;
private String sex;
private int age;
private boolean isStudent;
private String[] hobbies;
public String getName() {
return name;
}
public String getSex() {
return sex;
}
public int getAge() {
return age;
}
public boolean isStudent() {
return isStudent;
}
public String[] getHobbies() {
return hobbies;
}
public void setName(String name) {
this.name = name;
}
public void setSex(String sex) {
this.sex = sex;
}
public void setAge(int age) {
this.age = age;
}
public void setStudent(boolean student) {
isStudent = student;
}
public void setHobbies(String[] hobbies) {
this.hobbies = hobbies;
}
}
注:一定要有 Getter 跟 Setter 方法
main:
package cn.xiwh.test;
import cn.xiwh.bean.PersonInfo;
import org.json.JSONObject;
import org.junit.Test;
public class JSONTest {
@Test
public void javaBeanBuildJson() {
System.out.println(createJsonByJavaBean());
}
private static JSONObject createJsonByJavaBean() {
PersonInfo personInfo = new PersonInfo();
personInfo.setName("Bob");
personInfo.setAge(25);
personInfo.setSex("male");
personInfo.setStudent(true);
personInfo.setHobbies(new String[]{"篮球", "游泳"});
JSONObject object = new JSONObject(personInfo);
return object;
}
}
3. 解析json
解析json主要是基本类型如Number、boolean等,与数组Array。
基本类型的解析直接调用JSONObject对象的getXxx(key)方法,如果获取字符串则getString(key),布尔值则getBoolean(key),以此类推。
数组的解析稍微麻烦一点,需要通过JSONObject对象的getJSONArray(key)方法获取到一个JSONArray对象,再调用JSONArray对象的get(i)方法获取数组元素,i为索引值。
范例:
首先在工程目录"src/main/java"下创建一个json文件,用于解析。
test.json:
{
"hobbies": [
"playBilliards",
"swimming"
],
"sex": "male",
"name": "John",
"is_student": true,
"age": 22
}
在pom.xml中加入对 commons-io 的依赖,以便于使用FileUtils进行文件访问
主类:
package cn.xiwh.test;
import org.apache.commons.io.FileUtils;
import org.json.JSONArray;
import org.json.JSONObject;
import org.junit.Test;
import java.io.File;
import java.io.IOException;
public class JSONTest {
@Test
public void sampleExternalFile() throws IOException {
File file = new File("E:\\projects\\testJson\\src\\main\\java\\cn\\xiwh\\file\\test.json");
String content = FileUtils.readFileToString(file);
//对基本类型的解析
JSONObject obj = new JSONObject(content);
System.out.println("name:" + obj.getString("name"));
System.out.println("sex:" + obj.getString("sex"));
System.out.println("age:" + obj.getInt("age"));
System.out.println("is_student:" + obj.getBoolean("is_student"));
//对数组的解析
JSONArray hobbies = obj.getJSONArray("hobbies");
for (int i = 0; i < hobbies.length(); i++) {
System.out.println("hobbies:" + hobbies.get(i));
}
}
}
转载请注明出处:BestEternity亲笔。