FASTJSON 2
は、非常にパフォーマンスが高く、使いやすい Java JSON ライブラリです。
FASTJSON 2
FASTJSON
プロジェクトの重要なアップグレードであり、FASTJSON 1 と比較してパフォーマンスが大幅に向上し、互換性とホワイトリストによる autoType 機能のセキュリティ問題が解決されました。JDK 11
/ JDK 17
を含む新しい JDK 機能のサポート、 compact string
用に最適化、レコードのサポート、 GraalVM Native-Image
のサポートJSONPath
サポート、SQL:2016 JSONPath 構文のサポートAndroid 8+
、クライアントおよびサーバー用の API セットをサポートKotlin
サポート https://alibaba.github.io/fastjson2/kotlin_cnJSON Schema
のサポート https://alibaba.github.io/fastjson2/json_schema_cnfastjson 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 のサポートを参照してください。
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 );