นโยบายการตั้งชื่อฟิลด์ สามารถใช้เพื่อกำหนดรูปแบบการตั้งชื่อมาตรฐานสองสามแบบสำหรับชื่อฟิลด์ JSON และสามารถใช้ร่วมกับ GsonBuilder เพื่อกำหนดค่า Gson ตัวอย่าง เพื่อแปลชื่อฟิลด์ Java เป็นชื่อฟิลด์ JSON ที่ต้องการอย่างเหมาะสม เราสามารถใช้ setFieldNamingPolicy() วิธีการของ GsonBuilder เพื่อกำหนดค่ากลยุทธ์นโยบายการตั้งชื่อเฉพาะให้กับฟิลด์ของออบเจ็กต์ระหว่าง การทำให้เป็นอนุกรม และ ดีซีเรียลไลเซชัน .
Gson รองรับข้อกำหนดการตั้งชื่อฟิลด์ต่างๆ ด้วยนโยบายการตั้งชื่อฟิลด์ดังต่อไปนี้
- FieldNamingPolicy.IDENTITY :ใช้การตั้งชื่อเดียวกันกับโมเดล Java เมื่อสร้างอนุกรมอ็อบเจกต์
- FieldNamingPolicy.LOWER_CASE_WITH_UNDERSCORES :แก้ไขชื่อฟิลด์ Java จากรูปแบบอูฐเป็นชื่อฟิลด์ตัวพิมพ์เล็กโดยที่แต่ละคำถูกคั่นด้วยขีดล่าง (_)
- FieldNamingPolicy.LOWER_CASE_WITH_DASHES: มันแก้ไขชื่อฟิลด์ Java จากรูปแบบอูฐของมันไปเป็นชื่อฟิลด์ตัวพิมพ์เล็กโดยที่แต่ละคำถูกคั่นด้วยเครื่องหมายขีดกลาง (-)
- FieldNamingPolicy.UPPER_CAMEL_CASE :จะทำให้แน่ใจว่า "ตัวอักษร" ตัวแรกของชื่อฟิลด์ Java เป็นตัวพิมพ์ใหญ่เมื่อทำให้เป็นอนุกรมในแบบฟอร์ม JSON
- FieldNamingPolicy.UPPER_CAMEL_CASE_WITH_SPACES :จะทำให้แน่ใจว่า "ตัวอักษร" ตัวแรกของชื่อฟิลด์ Java เป็นตัวพิมพ์ใหญ่เมื่อทำให้เป็นอนุกรมในรูปแบบ JSON และคำจะถูกคั่นด้วยการเว้นวรรค
ตัวอย่าง
import com.google.gson.*; import java.sql.Date; import java.time.LocalDate; public class FieldNamingPolicyTest { public static void main(String[] args) { Gson gson = new GsonBuilder().setPrettyPrinting().setDateFormat("yyyy-MM- dd") .setFieldNamingPolicy(FieldNamingPolicy.LOWER_CASE_WITH_DASHES).create(); Person p = new Person("Raja", "Ramesh", 30, Date.valueOf(LocalDate.of(1988, 1, 1))); String jsonStr = gson.toJson(p); System.out.println(jsonStr); } } // Person class class Person { private String fistName; private String lastName; private int _age; private Date dateOfBirth; public Person(String fistName, String lastName, int _age, Date dateOfBirth) { super(); this.fistName = fistName; this.lastName = lastName; this._age = _age; this.dateOfBirth = dateOfBirth; } }
ผลลัพธ์
{ "fist-name": "Raja", "last-name": "Ramesh", "_age": 30, "date-of-birth": "1988-01-01" }