FASTJSON 2
é uma biblioteca Java JSON extremamente eficiente e fácil de usar.
FASTJSON 2
é uma atualização importante do projeto FASTJSON
Em comparação com FASTJSON 1, o desempenho foi bastante melhorado e os problemas de segurança da função autoType devido à compatibilidade e à lista de permissões foram resolvidos.JDK 11
/ JDK 17
, otimizado para compact string
, suporte Record, suporte GraalVM Native-Image
JSONPath
completo, com suporte à sintaxe SQL:2016 JSONPathAndroid 8+
, um conjunto de APIs para cliente e servidorKotlin
https://alibaba.github.io/fastjson2/kotlin_cnJSON Schema
https://alibaba.github.io/fastjson2/json_schema_cn Em fastjson v2
, groupId
é diferente de 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 '
}
Você pode visualizar a versão mais recente disponível em maven.org.
Fastjson v1
Se você usou originalmente a versão fastjson 1.2.x
, pode usar o pacote de compatibilidade. O pacote de compatibilidade não pode garantir 100% de compatibilidade.
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
Se o projeto usar Kotlin
, você poderá usar o módulo fastjson-kotlin
e adotar os recursos do kotlin
.
Maven
: < dependency >
< groupId >com.alibaba.fastjson2</ groupId >
< artifactId >fastjson2-kotlin</ artifactId >
< version >2.0.53</ version >
</ dependency >
Adicione a biblioteca padrão (kotlin-stdlib) e a biblioteca de reflexão (kotlin-reflect) conforme apropriado. Se você usar uma classe de dados (classe de dados) e passar parâmetros por meio do construtor, adicione a biblioteca de reflexão.
< 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
Se o projeto usar uma estrutura como SpringFramework
, você poderá usar o módulo fastjson-extension
Para uso, consulte Suporte 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 '
}
No fastjson v2
, package
é diferente de 1.x
, é com.alibaba.fastjson2
. Se você estava usando fastjson1
antes, na maioria dos casos você pode apenas alterar o nome do pacote.
JSON
em 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
em JSONArray
Java
:
String text = "..." ;
JSONArray data = JSON . parseArray ( text );
Kotlin
:
import com.alibaba.fastjson2.*
val text = .. . // String
val data = text.parseArray() // JSONArray
JSON
em objetos 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
para 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
e 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
para 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
Resultado da serialização:
{
"id" : 2 ,
"name" : " FastJson2 "
}
JSONB
JavaBean
JSONB
User user = ...;
byte [] bytes = JSONB . toBytes ( user );
byte [] bytes = JSONB . toBytes ( user , JSONWriter . Feature . BeanToArray );
JSONB
em JavaBean
byte [] bytes = ...
User user = JSONB . parseObject ( bytes , User . class );
User user = JSONB . parseObject ( bytes , User . class , JSONReader . Feature . SupportBeanArrayMapping );
JSONPath
JSONPath
para ler alguns dados String text = ...;
JSONPath path = JSONPath . of ( "$.id" ); // 缓存起来重复使用能提升性能
JSONReader parser = JSONReader . of ( text );
Object result = path . extract ( parser );
JSONPath
para ler dados byte[]
byte [] bytes = ...;
JSONPath path = JSONPath . of ( "$.id" ); // 缓存起来重复使用能提升性能
JSONReader parser = JSONReader . of ( bytes );
Object result = path . extract ( parser );
JSONPath
para ler dados byte[]
byte [] bytes = ...;
JSONPath path = JSONPath . of ( "$.id" ); // 缓存起来重复使用能提升性能
JSONReader parser = JSONReader . ofJSONB ( bytes ); // 注意这里使用ofJSONB方法
Object result = path . extract ( parser );