以下是使用 JDOM 库生成 XML 文件并返回 File 对象的完整代码实现,其中包含 JSON 数据作为 XML 内容:
java
import org.jdom2.Document;
import org.jdom2.Element;
import org.jdom2.output.Format;
import org.jdom2.output.XMLOutputter;
import java.io.File;
import java.io.FileWriter;
public class JsonToXmlGenerator {
public static void main(String[] args) {
// 最终生成的 File 对象
File xmlFile = generateXmlFile();
System.out.println("XML 文件路径: " + xmlFile.getAbsolutePath());
}
public static File generateXmlFile() {
try {
// 1. 准备 JSON 数据
String jsonData = "{\"product\":\"Laptop\", \"price\":1200}";
// 2. 构建 XML 结构(创建根节点和内容节点)[1][6]
Element root = new Element("jsonData"); // 创建根节点
Element content = new Element("content"); // 创建内容节点
content.setText(jsonData); // 设置 JSON 数据为文本内容
root.addContent(content); // 将内容节点添加到根节点
// 3. 创建文档对象并关联根节点 [2][5]
Document doc = new Document(root);
// 4. 配置 XML 输出格式(自动缩进/换行)[3][6]
Format format = Format.getPrettyFormat();
format.setIndent(" "); // 设置缩进为两个空格
format.setEncoding("UTF-8"); // 设置文件编码
// 5. 创建文件对象并写入数据 [4][7]
File outputFile = new File("output_jdom.xml"); // 创建 File 对象
XMLOutputter xmlOutput = new XMLOutputter(format);
try (FileWriter writer = new FileWriter(outputFile)) {
xmlOutput.output(doc, writer); // 将 XML 写入文件
}
return outputFile; // 返回生成的 File 对象
} catch (Exception e) {
e.printStackTrace();
return null;
}
}
}
📄 生成的文件内容 (output_jdom.xml)
java
<?xml version="1.0" encoding="UTF-8"?>
<jsonData>
<content>{"product":"Laptop", "price":1200}</content>
</jsonData>
⚙️ 关键步骤解析
数据结构构建
创建根节点 jsonData(Element 对象)
1
6
创建子节点 content 存放 JSON 字符串(通过 setText() 注入)
5
使用 addContent() 建立节点层级关系
6
输出配置
Format.getPrettyFormat():启用自动缩进格式化
3
6
setIndent(" "):设置双空格缩进(可调整)
setEncoding("UTF-8"):确保中文等特殊字符正常显示
6
文件操作
通过 File 对象指定输出路径(可自定义路径如 new File("data/output.xml"))
使用 try-with-resources 自动关闭 FileWriter,避免资源泄漏
4
最终返回包含 XML 数据的 File 对象
扩展建议
路径自定义:修改 new File("output_jdom.xml") 中的路径,如 D:/data/result.xml
动态内容:将 JSON 数据改为方法参数,实现动态生成:
java
public static File generateXmlFile(String jsonData, String filePath) {
// 替换固定JSON和路径为参数
File outputFile = new File(filePath);
// ...
}
异常处理:根据业务需求添加自定义异常(如文件写入权限检查)
4
此方案符合 XML 文件标准格式(含声明头和 UTF-8 编码),并通过 JDOM 的格式化输出保证可读性。返回的 File 对象可直接用于后续读写操作
1
3
6
。