使用 Gson 和 JAXB 通过示例将 JSON 转换为 XML Java

什么是JSON?

JSON 是 Javascript Object Notation 的缩写,它是一种数据形式,遵循大多数编程语言目前都能读懂的特定规则。我们可以轻松地将其保存到文件或数据库记录中。JSON 格式使用键值对来描述数据。

在接下来的示例中,我们定义了一个存储个人信息的 JSON 字符串

{
"username" : "guru99user",
"email" : "guru99user@mail.com"	
}

所以 JSON 的语法非常简单。每条数据信息都将包含两个部分:键和值,它们对应于某个记录中的字段名称及其值。但进一步查看,还有一些方面是这样的:

  • JSON 字符串用花括号 {} 括起来。
  • JSON 的键和值都必须用引号 {}“” 括起来。
  • 如果有更多数据(更多的键值对),我们使用逗号 (,) 分隔。
  • JSON 键应该是无符号的字母或数字、下划线,不允许有空格,首字符不能是数字。

什么是 XML?

XML 是 eXtensible Markup Language 的缩写,也称为可扩展标记语言,由万维网联盟 (World Wide Web Consortium) (https://www.w3.org/) 提出,用于创建其他标记语言。这是一个简单的子集,可以描述多种不同类型的数据,因此在系统之间共享数据时非常有用。

XML 中的标签通常不是预定义的,而是根据用户约定创建的。 XML 在 HTML 的优势基础上引入了新功能。

在各种系统和解决方案中,还有一些更有用的 XML 创建功能。

  • XML 是可扩展的:XML 允许您创建自己的自定义标签以适应您的应用程序。
  • XML 承载数据,不显示数据:XML 允许您存储数据,而不考虑如何显示。
  • XML 是通用标准:XML 由万维网联盟 (W3C) 开发,并作为开放标准提供。

XML 构建在嵌套节点结构上。每个节点将有一个开始标签和一个结束标签,如下所示:

<node>content</node>

其中

  • <node> 是一个开始标签,该标签的名称由您定义。
  • </node> 是一个结束标签,该标签的名称必须与开始标签的名称匹配。
  • content 是该标签的内容。

在每个 XML 文件的顶部,您必须声明一个标签来指示 XML 的使用版本。指令标签的语法是:

<?xml version="1.0" encoding="UTF-8" standalone="yes"?>

什么是 Gson?

Gson (https://github.com/google/gson) 是一个 Java 库,允许用户将 Java 对象转换为 JSON 字符串,也允许将 JSON 字符串转换为 Java 对象。Gson 可以处理任意 Java 对象,包括您没有其源代码的现有对象。

从 1.6 版本开始,Gson 引入了两个新类 – JsonReaderJsonWriter,用于对 JSON 数据提供流式处理。

  • JsonWriter – 流式写入 JSON。通用实现的语法如下。我们创建一个 JsonWriter 对象。要开始和结束创建 JSON 字符串,我们使用 beginObject()endObject() 函数。在执行这两个函数之间,我们使用键值对执行数据写入。
JsonWriter writer = new JsonWriter();
writer.beginObject();
writer.name("key").value("value");
writer.endObject();
  • JsonReader – 流式读取 JSON。通用实现的语法如下。我们创建一个 JsonReader 对象。要开始和结束创建 JSON 字符串,我们使用 beginObject() 和 endObject() 函数。在执行这两个函数之间,我们使用键值对读取数据。
JsonReader reader = new JsonReader();
reader.beginObject();
while (reader.hasNext()) {
	String name = reader.nextName();
	if (name.equals("key")) {
		String value = reader.nextString();
	}
}
reader.endObject();

Gson 的流式处理速度很快。但是,您需要处理 JSON 数据的每个键值对。

什么是 JAXB?

JAXB 是 Java Architecture for XML Binding 的缩写,它是一个使用注解将 Java 对象转换为 XML 内容并反之亦然的库。由于 JAXB 通过规范定义,我们可以为该标准使用不同的实现。

使用 JAXB,我们通常使用以下基本注解:

  • @XmlRootElement:此注解指定 XML 文件的最外层标签是什么,因此它声明在类之上。
  • @XmlElementWrapper:此注解在集合周围创建一个包装器 XML 元素。
  • @XmlElement:此注解用于声明对象的属性是 XML 文件的标签。
  • @XmlAttribute:此注解也用于声明对象的属性是 XML 文件的标签。

通用实现的语法如下。首先,我们将使用 MyObject 对象初始化 JAXBContext 对象进行转换。

JAXBContext jaxbContext = JAXBContext.newInstance(MyObject.class);

在这个 JAXBContext 对象中,它有一个方法可以创建一个将 XML 内容转换为 Java 对象的对象,即 Unmarshaller

Unmarshaller jaxbUnmarshaller = jaxbContext.createUnmarshaller();

在这个 JAXBContext 对象中,它有一个方法可以创建将 Java 对象转换为 XML 内容的对象,即 Marshaller

Marshaller marshallerObj = jaxbContext.createMarshaller();

如何将 XML 转换为 JSON?

我们在平台上实现了 XML – JSON 转换的示例。

  • Open JDK 8 for Ubuntu 18.04 x64。
  • Eclipse IDE 2019-03 (4.11.0) x64 Java Development for Ubuntu。
  • Gson 2.8.5。

步骤 1) 创建项目。
创建一个新的 Java 项目。

Create a new Java Project.
创建一个新的 Java 项目。

步骤 2) 设置项目名称。
将项目名称设置为 XmlToJsonExample

Set Project name

设置项目名称。

步骤 3) 创建文件夹。
创建文件夹 data/input,其中包含两个文件 sample.xmlsample.json

Create folder data

创建文件夹 data/input。

让我们首先定义包含 departmentroleperson 属性的 XML。

总体架构是:<一个部门 – 多个角色>;<一个角色 – 多个人员>。

Object Relationships

对象关系。

<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<root>
	<department>
		<roles>
			<role id="1">
				<position>head</position>
				<salary>10k</salary>
			</role>
			<role id="2">
				<position>manager</position>
				<salary>8k</salary>
			</role>
			<role id="3">
				<position>employee</position>
				<salary>5k</salary>
			</role>
		</roles>
		<persons>
			<person id="1">
				<name>Red</name>
				<role>1</role>
			</person>
			<person id="2">
				<name>Green</name>
				<role>2</role>
			</person>
			<person id="3">
				<name>Blue</name>
				<role>2</role>
			</person>
			<person id="4">
				<name>Yellow</name>
				<role>3</role>
			</person>
			<person id="5">
				<name>Brown</name>
				<role>3</role>
			</person>
		</persons>
	</department>
</root>

其次,我们定义具有相同想法的 JSON。

{
	"roles": [
		{
			"id": "1",
			"position": "head",
			"salary": "10k",
			"persons": [
				{
					"id": "1",
					"name": "Red"
				}
			]
		},
		{
			"id": "2",
			"position": "manager",
			"salary": "8k",
			"persons": [
				{
					"id": "2",
					"name": "Green"
				},
				{
					"id": "3",
					"name": "Blue"
				}
			]
		},
		{
			"id": "3",
			"position": "employee",
			"salary": "5k",
			"persons": [
				{
					"id": "4",
					"name": "Yellow"
				},
				{
					"id": "5",
					"name": "Brown"
				}
			]
		}
	]	
}

步骤 4) 定义对象。
model 包中定义相应的对象类。

Define object classes

定义对象类。

  • Role.java
@XmlRootElement(name = "role")
public class Role {
	private String id;
	private String position;
	private String salary;
	public Role() {
		super();
	}
	public Role(String id, String position, String salary) {
		super();
		this.id = id;
		this.position = position;
		this.salary = salary;
	}
	@XmlAttribute(name = "id")
	public String getId() {
		return id;
	}
	public void setId(String id) {
		this.id = id;
	}
	@XmlElement(name = "position")
	public String getPosition() {
		return position;
	}
	public void setPosition(String position) {
		this.position = position;
	}
	@XmlElement(name = "salary")
	public String getSalary() {
		return salary;
	}
	public void setSalary(String salary) {
		this.salary = salary;
	}
}
  • Person.java
@XmlRootElement(name = "person")
public class Person {
	private String id;
	private String name;
	private String role;
	public Person() {
		super();
	}
	public Person(String id, String name, String role) {
		super();
		this.id = id;
		this.name = name;
		this.role = role;
	}
	@XmlAttribute(name = "id")
	public String getId() {
		return id;
	}
	public void setId(String id) {
		this.id = id;
	}
	@XmlElement(name = "name")
	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}
	@XmlElement(name = "role")
	public String getRole() {
		return role;
	}
	public void setRole(String role) {
		this.role = role;
	}
}
  • Department.java
@XmlRootElement(name = "department")
public class Department {
	private List<Role> roles;
	private List<Person> persons;
	public Department() {
		super();
	}
	public Department(List<Role> roles, List<Person> persons) {
		super();
		this.roles = roles;
		this.persons = persons;
	}
	@XmlElementWrapper(name = "roles")
	@XmlElement(name = "role")
	public List<Role> getRoles() {
		return roles;
	}
	public void setRoles(List<Role> roles) {
		this.roles = roles;
	}
	@XmlElementWrapper(name = "persons")
	@XmlElement(name = "person")
	public List<Person> getPersons() {
		return persons;
	}
	public void setPersons(List<Person> persons) {
		this.persons = persons;
	}
}

XMLModel.java

@XmlRootElement(name = "root")
public class XMLModel {

	private Department department;

	public XMLModel() {
		super();
	}

	public XMLModel(Department department) {
		super();
		this.department = department;
	}

	@XmlElement(name = "department")
	public Department getDepartment() {
		return department;
	}

	public void setDepartment(Department department) {
		this.department = department;
	}

}

步骤 5) 设置库。
将 Gson 2.8.5 库添加到 Java 构建路径并进行设置。

Set up library Gson

Add library Gson 2.8.5 into Java Build Path

将库 Gson 2.8.5 添加到 Java 构建路径。

使用 JAXB 将 XML 消息转换为 Java 对象

首先,我们在 service 包中定义执行类。

Define performing classes

定义执行类。

在第一个过程的第一步中,我们使用 JAXB 的解组 (Un-marshalling) 技术。

解组为客户端应用程序提供了将 XML 数据转换为 JAXB 派生 Java 对象的能力。

我们定义了 getObjectFromXmlFile 函数,用于将 XML 文件解组回 Java 对象。此函数定义在 XMLService 类中。

public XMLModel getObjectFromXmlFile(String filePath) {
	try {
		File file = new File(filePath);
		JAXBContext jaxbContext = JAXBContext.newInstance(XMLModel.class);

		Unmarshaller jaxbUnmarshaller = jaxbContext.createUnmarshaller();
		XMLModel root = (XMLModel) jaxbUnmarshaller.unmarshal(file);

		return root;
	} catch (JAXBException e) {
		e.printStackTrace();
		return null;
	}
}

我们在 XmlToJsonService 类中调用上述代码。

XMLService xmlService = new XMLService();
XMLModel xmlModel = xmlService.getObjectFromXmlFile(filePathIn);

Department department = xmlModel.getDepartment();
List<Role> roles = department.getRoles();
List<Person> persons = department.getPersons();

然后我们进行下一步。

使用 Gson 将 Java 对象转换为 JSON 消息

在此步骤中,我们定义了 writeDataToJsonFile 函数,用于将数据写入 JSON 文件。此函数定义在 JsonService 类中。

请注意,要写入 JSON 字符串列表,我们使用 beginArray()endArray() 函数。在这两个函数之间,我们写入每个 JSON 字符串。

public void writeDataToJsonFile(String filePath, List<Role> roles, List<Person> persons) {
	try {
		JsonWriter writer = new JsonWriter(new FileWriter(filePath));
		writer.setIndent("    ");
		writer.beginObject();
		writer.name("roles");
		writer.beginArray();
		for (Role role : roles) {
			writer.beginObject();
			writer.name("id").value(role.getId());
			writer.name("position").value(role.getPosition());
			writer.name("salary").value(role.getSalary());
			writer.name("persons");
			writer.beginArray();
			for (Person person : persons) {
				if (person.getRole().equalsIgnoreCase(role.getId())) {
					writer.beginObject();
					writer.name("id").value(person.getId());
					writer.name("name").value(person.getName());
					writer.endObject();
				}
			}
			writer.endArray();
			writer.endObject();
		}
		writer.endArray();
		writer.endObject();
		writer.close();
	} catch (IOException e) {
	}
}

我们在 XmlToJsonService 类中调用上述代码。

JsonService jsonService = new JsonService();
jsonService.writeDataToJsonFile(filePathOut, roles, persons);

这就是第一个过程。

使用 Gson 将 JSON 消息转换为 Java 对象

在第二个过程的第一步中,我们定义了 getDataFromJsonFile 函数,用于从 JSON 文件读取数据。此函数定义在 JsonService 类中。

请注意,要读取 JSON 字符串列表,我们使用 beginArray()endArray() 函数。在这两个函数之间,我们读取每个 JSON 字符串。

public void getDataFromJsonFile(String filePath, List<Role> roles, List<Person> persons) {
	try {
		JsonReader reader = new JsonReader(new FileReader(filePath));
		reader.beginObject();
		while (reader.hasNext()) {
			String nameRoot = reader.nextName();
			if (nameRoot.equals("roles")) {
				reader.beginArray();
				while (reader.hasNext()) {
					reader.beginObject();
					Role role = new Role();
					while (reader.hasNext()) {
						String nameRole = reader.nextName();
						if (nameRole.equals("id")) {
							role.setId(reader.nextString());
						} else if (nameRole.equals("position")) 
					        { role.setPosition(reader.nextString());
						} else if (nameRole.equals("salary")) {
						  role.setSalary(reader.nextString());
						} else if (nameRole.equals("persons")) {
							reader.beginArray();
							while (reader.hasNext()) {
								reader.beginObject();

Person person = new Person();

						person.setRole(role.getId());

						while (reader.hasNext()) {
						String namePerson = reader.nextName();

							if (namePerson.equals("id")) {
						person.setId(reader.nextString());
						} else if (namePerson.equals("name")) {
						person.setName(reader.nextString());
							}
						}
								persons.add(person);
								reader.endObject();
							}
							reader.endArray();
						}
					}
					roles.add(role);
					reader.endObject();
				}
				reader.endArray();
			}
		}
		reader.endObject();
		reader.close();
	} catch (IOException e) {

	}
}

我们在 XmlToJsonService 类中调用上述代码。

JsonService jsonService = new JsonService();
List<Role> roles = new ArrayList<>();
List<Person> persons = new ArrayList<>();

jsonService.getDataFromJsonFile(filePathIn, roles, persons);

如何将 Json 转换为 XML Java?

JAVA 中的 JSON 到 XML 转换是通过使用 JSONObject json = new JSONObject(str); String xml = XML. 来实现的。如果您有一个有效的 DTD 文件或 XML 文件,那么将 JSON 转换为 XML 和 XML 转换为 JSON 非常容易。

然后我们进行下一步。

使用 JAXB 将 Java 对象转换为 XML 消息

在此步骤中,我们使用 JAXB 的编组 (Marshalling) 技术。

编组为客户端应用程序提供了将 JAXB 派生 Java 对象树转换为 XML 数据的能力。

我们定义了 parseObjectToXm 函数,用于将 Java 对象编组为 XML 消息。此函数定义在类中:

XMLService.
public void parseObjectToXml(String filePath, XMLModel xmlModel) {
	try {
		JAXBContext contextObj = JAXBContext.newInstance(XMLModel.class);

		Marshaller marshallerObj = contextObj.createMarshaller();
		marshallerObj.setProperty(Marshaller.JAXB_FORMATTED_OUTPUT, true);

		marshallerObj.marshal(xmlModel, new FileOutputStream(filePath));
	} catch (JAXBException je) {
		System.out.println("JAXBException");
	} catch (IOException ie) {
		System.out.println("IOException");
	}
}

我们在 XmlToJsonService 类中调用上述代码。

XMLService xmlService = new XMLService();
XMLModel xmlModel = new XMLModel();

Department department = new Department();
department.setRoles(roles);
department.setPersons(persons);

xmlModel.setDepartment(department);

xmlService.parseObjectToXml(filePathOut, xmlModel);

这就是第二个过程。

结论

在本教程中,我们简要学习了一种方法,JAXB 可以读取 XML 数据并使用 Gson 将其写入 JSON。相反,我们也看到了 Gson 读取 JSON 数据并通过 JAXB 将其写入 XML 的方法。