java解析json方法總結(jié)
工具包org.json.jar,是一個(gè)輕量級(jí)的,JAVA下的json構(gòu)造和解析工具包,它還包含JSON與XML, HTTP headers, Cookies, CDL的轉(zhuǎn)換。
這里推薦使用:阿里巴巴FastJson是一個(gè)Json處理工具包,包括“序列化”和“反序列化”兩部分,它具備如下特征:
速度最快,測(cè)試表明,fastjson具有極快的性能,超越任其他的Java Json parser。包括自稱最快的JackJson;
功能強(qiáng)大,完全支持Java Bean、集合、Map、日期、Enum,支持范型,支持自??;無依賴,能夠直接運(yùn)行在Java SE 5.0以上版本;支持Android;開源 (Apache 2.0)
源碼地址:
https://github.com/alibaba/fastjson
Fastjson API入口類是com.alibaba.fastjson.JSON,常用的序列化操作都可以在JSON類上的靜態(tài)方法直接完成。
public static final Object parse(String text); // 把JSON文本parse為JSONObject或者JSONArray
public static final JSONObject parseObject(String text); // 把JSON文本parse成JSONObject
public static final T parseObject(String text, Class clazz); // 把JSON文本parse為JavaBean
public static final JSONArray parseArray(String text); // 把JSON文本parse成JSONArray
public static final List parseArray(String text, Class clazz); //把JSON文本parse成JavaBean集合
public static final String toJSONString(Object object); // 將JavaBean序列化為JSON文本
public static final String toJSONString(Object object, boolean prettyFormat); // 將JavaBean序列化為帶格式的JSON文本
public static final Object toJSON(Object javaObject); 將JavaBean轉(zhuǎn)換為JSONObject或者JSONArray。
以上都是一些項(xiàng)目中的常用方法。
以下是自己練習(xí)寫的代碼:
package com.test;
public class TestPerson {
private int age;
private String name;
public TestPerson(){
}
public TestPerson(int age,String name){
this.age=age;
this.name=name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
package com.test;
import java.util.*;
import com.alibaba.fastjson.*;
public final class TestFastJson {
public static void main(String[] args) {
// TODO Auto-generated method stub
TestPerson json = new TestPerson(19,"李明");
List<TestPerson> list = new ArrayList<TestPerson>();
list.add(json);
list.add(new TestPerson(12,"張三"));
//將集合或者對(duì)象序例化成JSON
System.out.println(JSON.toJSON(json));
System.out.println( JSON.toJSON(list) );
//Json串反序列化成對(duì)象
TestPerson person = JSON.parseObject("{\"name\":\"李明\",\"age\":19}", TestPerson.class);
System.out.printf("name:%s,age:%d\n",person.getName(),person.getAge());
String str = "[{\"name\":\"李明\",\"age\":19},{\"name\":\"張三\",\"age\":12}]";
//數(shù)組對(duì)象反序列化成集合
List<TestPerson> listPerson = JSON.parseArray(str,TestPerson.class);
for(TestPerson item : listPerson){
System.out.println( item.getName() );
System.out.println( item.getAge());
}
//沒有對(duì)象直接解析JSON對(duì)象
JSONObject jobj = JSON.parseObject("{\"name\":\"李明\",\"age\":19}");
System.out.printf("name:%s,age:%d\n",jobj.getString("name"),jobj.getBigInteger("age"));
//沒有對(duì)象直接解析JSON數(shù)組
JSONArray jarr = JSON.parseArray("[{\"name\":\"李明\",\"age\":19},{\"name\":\"張三\",\"age\":12}]");
for(int i=0,len=jarr.size();i<len;i++){
JSONObject temp= jarr.getJSONObject(i);
System.out.printf("name:%s,age:%d\n",temp.getString("name"),temp.getBigInteger("age"));
}
for(Object obj:jarr){
System.out.println(obj.toString());
}
}
}
相關(guān)文章
PHP 匿名函數(shù)與注意事項(xiàng)詳細(xì)介紹
這篇文章主要介紹了PHP 匿名函數(shù)與注意事項(xiàng)詳細(xì)介紹的相關(guān)資料,匿名函數(shù)是PHP5.3引進(jìn)來了,php5.3不但引進(jìn)了匿名函數(shù)還有更多更好多新的特性了,下面我們一起來了解一下PHP匿名函數(shù)與注意事項(xiàng)詳解,需要的朋友可以參考下2016-11-11
php將access數(shù)據(jù)庫轉(zhuǎn)換到mysql數(shù)據(jù)庫的方法
這篇文章主要介紹了php將access數(shù)據(jù)庫轉(zhuǎn)換到mysql數(shù)據(jù)庫的方法,可實(shí)現(xiàn)讀取access數(shù)據(jù)庫數(shù)據(jù)并寫入到mysql數(shù)據(jù)庫中,具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2014-12-12
PHP中的str_repeat函數(shù)在JavaScript中的實(shí)現(xiàn)
PHP中有一個(gè)函數(shù):String str_repeat($str, num);挺好用的,在 本文為大家介紹下次函數(shù)在js中的實(shí)現(xiàn),感興趣的朋友可以參考下2013-09-09
PHP 計(jì)算代碼執(zhí)行耗時(shí)的代碼修正網(wǎng)上普遍錯(cuò)誤
前幾天測(cè)試 SQLite 插入大數(shù)據(jù)量的時(shí)候, 找了一些關(guān)于計(jì)算執(zhí)行時(shí)間的代碼, 發(fā)現(xiàn)網(wǎng)上普遍流傳著這樣一份代碼2011-05-05
PHP實(shí)現(xiàn)獲取文件mime類型多種方法解析
這篇文章主要介紹了PHP實(shí)現(xiàn)獲取文件mime類型多種方法解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-05-05
php使用vue實(shí)現(xiàn)省市區(qū)三級(jí)聯(lián)動(dòng)
這篇文章主要為大家詳細(xì)介紹了php如何使用vue實(shí)現(xiàn)省市區(qū)三級(jí)聯(lián)動(dòng)效果,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2023-12-12
PHP操作SQL Server數(shù)據(jù)庫實(shí)現(xiàn)表的改查與統(tǒng)計(jì)
這篇文章主要介紹了如何利用PHP對(duì)MS SQL Server數(shù)據(jù)表的查詢、統(tǒng)計(jì)與修改,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2022-03-03
PhpStorm+xdebug+postman調(diào)試技巧分享
寫PHP時(shí),一直用postman做測(cè)試,最近發(fā)現(xiàn)在測(cè)試過程中可以用xdebug來斷點(diǎn)調(diào)試,比原來手動(dòng)打exit或者die來斷點(diǎn)效率高多了2020-09-09

