fastjson2
fastjson 2.0.53版本发布
FASTJSON 2
是一個效能極致且簡單易用的Java JSON函式庫。
FASTJSON 2
是FASTJSON
專案的重要升級,和FASTJSON 1相比,效能有非常大的提升,解決了autoType功能因為相容和白名單的安全性問題。JDK 11
/ JDK 17
,針對compact string
優化,支援Record,支援GraalVM Native-Image
JSONPath
支持,支援SQL:2016的JSONPath語法Android 8+
,客戶端和伺服器一套APIKotlin
https://alibaba.github.io/fastjson2/kotlin_cnJSON Schema
https://alibaba.github.io/fastjson2/json_schema_cn在fastjson v2
中, groupId
和1.x
不一樣,是com.alibaba.fastjson2
:
Maven
:
< dependency >
< groupId >com.alibaba.fastjson2</ groupId >
< artifactId >fastjson2</ artifactId >
< version >2.0.53</ version >
</ dependency >
Gradle
:
dependencies {
implementation ' com.alibaba.fastjson2:fastjson2:2.0.53 '
}
可以在maven.org 查看最新可用的版本。
Fastjson v1
相容模組如果原來使用fastjson 1.2.x
版本,可以使用相容包,相容包不能保證100%相容,請仔細測試驗證,發現問題請及時回饋。
Maven
:
< dependency >
< groupId >com.alibaba</ groupId >
< artifactId >fastjson</ artifactId >
< version >2.0.53</ version >
</ dependency >
Gradle
:
dependencies {
implementation ' com.alibaba:fastjson:2.0.53 '
}
Fastjson Kotlin
整合模組如果專案使用Kotlin
,可以使用fastjson-kotlin
模組,使用方式上採用kotlin
的特性。
Maven
: < dependency >
< groupId >com.alibaba.fastjson2</ groupId >
< artifactId >fastjson2-kotlin</ artifactId >
< version >2.0.53</ version >
</ dependency >
酌情加入標準函式庫(kotlin-stdlib)、反射函式庫(kotlin-reflect), 其中若使用資料類別(data class)、透過建構函式傳入參數則加入反射函式庫。
< dependency >
< groupId >org.jetbrains.kotlin</ groupId >
< artifactId >kotlin-stdlib</ artifactId >
< version >${kotlin-version}</ version >
</ dependency >
< dependency >
< groupId >org.jetbrains.kotlin</ groupId >
< artifactId >kotlin-reflect</ artifactId >
< version >${kotlin-version}</ version >
</ dependency >
Kotlin Gradle
: dependencies {
implementation( " com.alibaba.fastjson2:fastjson2-kotlin:2.0.53 " )
}
dependencies {
implementation( " org.jetbrains.kotlin:kotlin-stdlib: $kotlin_version " )
implementation( " org.jetbrains.kotlin:kotlin-reflect: $kotlin_version " )
}
Fastjson Extension
擴充模組如果專案使用SpringFramework
等框架,可以使用fastjson-extension
模組,使用方式參考SpringFramework Support。
Maven
:
< dependency >
< groupId >com.alibaba.fastjson2</ groupId >
< artifactId >fastjson2-extension-spring5</ artifactId >
< version >2.0.53</ version >
</ dependency >
< dependency >
< groupId >com.alibaba.fastjson2</ groupId >
< artifactId >fastjson2-extension-spring6</ artifactId >
< version >2.0.53</ version >
</ dependency >
Gradle
:
dependencies {
implementation ' com.alibaba.fastjson2:fastjson2-extension-spring5:2.0.53 '
}
dependencies {
implementation ' com.alibaba.fastjson2:fastjson2-extension-spring6:2.0.53 '
}
在fastjson v2
中, package
和1.x
不一樣,是com.alibaba.fastjson2
。如果你之前用的是fastjson1
,大多數情況都直接比較包名就可以。
JSON
解析為JSONObject
Java
:
String text = "..." ;
JSONObject data = JSON . parseObject ( text );
byte [] bytes = ...;
JSONObject data = JSON . parseObject ( bytes );
Kotlin
:
import com.alibaba.fastjson2.*
val text = .. . // String
val data = text.parseObject()
val bytes = .. . // ByteArray
val data = bytes.parseObject() // JSONObject
JSON
解析為JSONArray
Java
:
String text = "..." ;
JSONArray data = JSON . parseArray ( text );
Kotlin
:
import com.alibaba.fastjson2.*
val text = .. . // String
val data = text.parseArray() // JSONArray
JSON
解析為Java
對象Java
:
String text = "..." ;
User data = JSON . parseObject ( text , User . class );
Kotlin
:
import com.alibaba.fastjson2.*
val text = .. . // String
val data = text.to< User >() // User
val data = text.parseObject< User >() // User
Java
物件序列化為JSON
Java
:
Object data = "..." ;
String text = JSON . toJSONString ( data );
byte [] text = JSON . toJSONBytes ( data );
Kotlin
:
import com.alibaba.fastjson2.*
val data = .. . // Any
val text = text.toJSONString() // String
val bytes = text.toJSONByteArray() // ByteArray
JSONObject
、 JSONArray
String text = "{ " id " : 2, " name " : " fastjson2 " }" ;
JSONObject obj = JSON . parseObject ( text );
int id = obj . getIntValue ( "id" );
String name = obj . getString ( "name" );
String text = "[2, " fastjson2 " ]" ;
JSONArray array = JSON . parseArray ( text );
int id = array . getIntValue ( 0 );
String name = array . getString ( 1 );
JavaBean
Java
:
JSONArray array = ...
JSONObject obj = ...
User user = array . getObject ( 0 , User . class );
User user = obj . getObject ( "key" , User . class );
Kotlin
:
val array = .. . // JSONArray
val obj = .. . // JSONObject
val user = array.to< User >( 0 )
val user = obj.to< User >( " key " )
JavaBean
Java
:
JSONArray array = ...
JSONObject obj = ...
User user = obj . toJavaObject ( User . class );
List < User > users = array . toJavaList ( User . class );
Kotlin
:
val array = .. . // JSONArray
val obj = .. . // JSONObject
val user = obj.to< User >() // User
val users = array.toList< User >() // List<User>
JavaBean
物件序列化為JSON
Java
:
class User {
public int id ;
public String name ;
}
User user = new User ();
user . id = 2 ;
user . name = "FastJson2" ;
String text = JSON . toJSONString ( user );
byte [] bytes = JSON . toJSONBytes ( user );
Kotlin
:
class User (
var id : Int ,
var name : String
)
val user = User ()
user.id = 2
user.name = " FastJson2 "
val text = user.toJSONString() // String
val bytes = user.toJSONByteArray() // ByteArray
序列化結果:
{
"id" : 2 ,
"name" : " FastJson2 "
}
JSONB
JavaBean
物件序列化JSONB
User user = ...;
byte [] bytes = JSONB . toBytes ( user );
byte [] bytes = JSONB . toBytes ( user , JSONWriter . Feature . BeanToArray );
JSONB
資料解析為JavaBean
byte [] bytes = ...
User user = JSONB . parseObject ( bytes , User . class );
User user = JSONB . parseObject ( bytes , User . class , JSONReader . Feature . SupportBeanArrayMapping );
JSONPath
JSONPath
讀取部分數據 String text = ...;
JSONPath path = JSONPath . of ( "$.id" ); // 缓存起来重复使用能提升性能
JSONReader parser = JSONReader . of ( text );
Object result = path . extract ( parser );
JSONPath
讀取部分byte[]
的數據 byte [] bytes = ...;
JSONPath path = JSONPath . of ( "$.id" ); // 缓存起来重复使用能提升性能
JSONReader parser = JSONReader . of ( bytes );
Object result = path . extract ( parser );
JSONPath
讀取部分byte[]
的數據 byte [] bytes = ...;
JSONPath path = JSONPath . of ( "$.id" ); // 缓存起来重复使用能提升性能
JSONReader parser = JSONReader . ofJSONB ( bytes ); // 注意这里使用ofJSONB方法
Object result = path . extract ( parser );