Gson @Expose 주석 직렬화 또는 역직렬화에 대해 필드를 노출할지 여부(포함 여부)를 표시하는 데 사용할 수 있습니다. @Expose 주석 두 개의 매개변수를 사용할 수 있으며 각 매개변수는 true 값 중 하나를 취할 수 있는 부울입니다. 또는 거짓 . GSON이 @Expose 주석에 반응하도록 하려면 GsonBuilder 를 사용하여 Gson 인스턴스를 생성해야 합니다. 클래스를 호출하고 excludeFieldsWithoutExposeAnnotation() 메소드에서 Expose 주석이 없는 직렬화 또는 역직렬화의 고려 대상에서 모든 필드를 제외하도록 Gson을 구성합니다.
구문
public GsonBuilder excludeFieldsWithoutExposeAnnotation()
예시
import com.google.gson.*;
import com.google.gson.annotations.*;
public class JsonExcludeAnnotationTest {
public static void main(String args[]) {
Employee emp = new Employee("Raja", 28, 40000.00);
Gson gson = new GsonBuilder().setPrettyPrinting().create();
String jsonStr = gson.toJson(emp);
System.out.println(jsonStr);
gson = new GsonBuilder().setPrettyPrinting().excludeFieldsWithoutExposeAnnotation().create();
jsonStr = gson.toJson(emp);
System.out.println(jsonStr);
}
}
// Employee class
class Employee {
@Expose(serialize = true, deserialize = true)
public String name;
@Expose(serialize = true, deserialize = true)
public int age;
@Expose(serialize = false, deserialize = false)
public double salary;
public Employee(String name, int age, double salary) {
this.name = name;
this.age = age;
this.salary = salary;
}
} 출력
{
"name": "Raja",
"age": 28,
"salary": 40000.0
}
{
"name": "Raja",
"age": 28
}