【轉載】使用JSONObject生成和解析json

使用JSONObject生成和解析json

1. json數據類型

類型描述
Number 數字型
String 字符串型
Boolean 布爾型
Array 數組
Object 對象
null 空值

(1)json中不區分整數、小數等類型,而統一使用Number來存儲數字。

(2)Array表示數組,以中括號"[]"括起來,元素之間以逗號分隔,元素可以爲任意類型。

(3)Object表示對象,類似於C語言中的結構體,以花括號"{}"括起來,其元素要求爲鍵值對,key必須爲String類型的,而value則可爲任意類型。key和value之間以":"表示映射關係,元素之間也是以逗號分隔。

2. 構建json

在eclipse中使用JSONObject需要引用org.json包,推薦通過maven引用,如果不會使用maven,搭建maven項目可參考這篇文章《使用Eclipse構建Maven項目 (step-by-step)》,引用json則參考這篇文章《maven引入json各種版本》

溫馨提示:我在構建maven項目的時候屢屢創建失敗,在網上查了很久還是搞不定,後來科學上網就搞定了,如果你也創建失敗,可以嘗試一下。

如果是在Android Studio中,則可以直接使用。

2.1 直接構建

JSONObject obj = new JSONObject();
obj.put(key, value);

直接構建即直接實例化一個JSONObject對象,而後調用其put()方法,將數據寫入。put()方法的第一個參數爲key值,必須爲String類型,第二個參數爲value,可以爲boolean、double、int、long、Object、Map以及Collection等。當然,double以及int等類型只是在Java中,寫入到json中時,統一都會以Number類型存儲。

範例:

import org.json.JSONObject;

public class JSONObjectSample {

    public static void main(String[] args) {
        createJson();
    }

    private static void createJson() {
        JSONObject obj = new JSONObject();
        obj.put("name", "John");
        obj.put("sex", "male");
        obj.put("age", 22);
        obj.put("is_student", true);
        obj.put("hobbies", new String[] {"hiking", "swimming"});
        //調用toString()方法可直接將其內容打印出來
        System.out.println(obj.toString());
    }

}

輸出結果爲:

{"hobbies":["hiking","swimming"],"sex":"male","name":"John","is_student":true,"age":22}

這裏可以看到,爲了壓縮大小以便於更高效地傳輸,json把所有空格、換行符等空白符全部去掉了。如果想要直觀點看其內容,可以用一些在線的json解析器看,例如:http://www.jsoneditoronline.org/

2.2 使用HashMap構建

使用HashMap構建json,實際上即先創建好一個HashMap對象並且將數據打包進去,而後在創建JSONObject時將其作爲一個參數傳進去。

範例:

public class JSONObjectSample {

    public static void main(String[] args) {
        createJsonByMap();
    }

    private static void createJsonByMap() {
        Map<String, Object> data = new HashMap<String, Object>();
        data.put("name", "John");
        data.put("sex", "male");
        data.put("age", 22);
        data.put("is_student", true);
        data.put("hobbies", new String[] {"hiking", "swimming"});
        
        JSONObject obj = new JSONObject(data);
        System.out.println(obj.toString());
    }

}

2.3 使用JavaBean構建

相較於前兩種方法,實際開發中應用JavaBean構建json的情況更爲常見,因爲這樣代碼的重用率更高。

範例:

JavaBean:

public class PersonInfo {

    private String name;
    private String sex;
    private int age;
    private boolean isStudent;
    private String[] 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 isStudent) {
        this.isStudent = isStudent;
    }
    public void setHobbies(String[] hobbies) {
        this.hobbies = hobbies;
    }
        //getter不能少
    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;
    }
}

main:

import org.json.JSONObject;

public class JSONObjectSample {

    public static void main(String[] args) {
        createJsonByJavaBean();
    }

    private static void createJsonByJavaBean() {
        PersonInfo info = new PersonInfo();
        info.setName("John");
        info.setSex("male");
        info.setAge(22);
        info.setStudent(true);
        info.setHobbies(new String[] {"hiking", "swimming"});
        
        JSONObject obj = new JSONObject(info);
        System.out.println(obj);
    }

}

需要注意一點,JavaBean一定要有getter方法,否則會無法訪問存儲的數據。

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文件,用於解析。

demo.json:

{
  "hobbies": [
    "hiking",
    "swimming"
  ],
  "sex": "male",
  "name": "John",
  "is_student": true,
  "age": 22
}

在pom.xml中加入對commons-io的依賴,以便於使用FileUtils進行文件訪問:

<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">
  <modelVersion>4.0.0</modelVersion>

  <groupId>com.studying</groupId>
  <artifactId>myjson</artifactId>
  <version>0.0.1-SNAPSHOT</version>
  <packaging>jar</packaging>

  <name>myjson</name>
  <url>http://maven.apache.org</url>

  <properties>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
  </properties>

  <dependencies>
    <dependency>
      <groupId>org.json</groupId>
      <artifactId>json</artifactId>
      <version>20160810</version>
    </dependency>
    <!--加入對commons-io的依賴-->
    <dependency>
      <groupId>commons-io</groupId>
      <artifactId>commons-io</artifactId>
      <version>2.4</version>
    </dependency>
  </dependencies>
</project>

主類:

import java.io.File;
import java.io.IOException;

import org.apache.commons.io.FileUtils;
import org.json.JSONArray;
import org.json.JSONObject;

public class JSONObjectSample {

    public static void main(String[] args) throws IOException {
        File file = new File("src/main/java/demo.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");
        System.out.println("hobbies:");
        for (int i = 0; i < hobbies.length(); i++) {
            String s = (String) hobbies.get(i);
            System.out.println(s);
        }
    }
}

轉自:https://www.cnblogs.com/joahyau/p/6736637.html#undefined
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章