Я пытаюсь сериализовать экземпляр Java с полями, подобными приведенным ниже.
public class Person{
private String firstName;
private String lastName;
public String getFirstName() {
return firstName;
}
public void setFirstName(String firstName) {
this.firstName = firstName;
}
public String getLastName() {
return lastName;
}
public void setLastName(String lastName) {
this.lastName = lastName;
}
}
Как мне сериализовать их под другими именами, чем имена реальных полей?В Gson
это возможно при использовании аннотации @SerializedName("first-name")
следующим образом.
@SerializedName("first-name")
private String firstName;
Есть ли что-то похожее на описанное выше в snakeyaml
.Подробности зависимости для snakeyaml
выглядят следующим образом:
<dependency>
<groupId>org.yaml</groupId>
<artifactId>snakeyaml</artifactId>
<version>1.17</version>
</dependency>
Ниже приведен основной класс программы с ответом, предоставленным flyx
public class Demo {
public static void main(String[] args) {
Person person = new Person();
person.setFirstName("Kasun");
person.setLastName("Siyambalapitiya");
Constructor constructor = new Constructor(Person.class);
Representer representer = new Representer();
TypeDescription personDesc = new TypeDescription(Person.class);
personDesc.substituteProperty("first-name", Person.class, "getFirstName", "setFirstName");
personDesc.substituteProperty("last-name", Person.class, "getLastName", "setLastName");
constructor.addTypeDescription(personDesc);
representer.addTypeDescription(personDesc);
Yaml yaml = new Yaml(constructor, representer);
String yamlString = yaml.dumpAs(person, Tag.MAP, DumperOptions.FlowStyle.BLOCK);
Path updateDescriptorFilePath =
Paths.get(File.separator + "tmp" + File.separator + "sample.json");
try {
FileUtils.writeStringToFile(updateDescriptorFilePath.toFile(), yamlString);
} catch (IOException e) {
System.out.println(e.getCause());
}
}
}
.следующий вывод
/tmp cat sample.json
first-name: Kasun
last-name: Siyambalapitiya
firstName: Kasun
lastName: Siyambalapitiya
/tmp