使用 JDOM 库生成 XML 文件并返回 File
以下是使用 JDOM 库生成 XML 文件并返回 File 对象的完整代码实现,其中包含 JSON 数据作为 XML 内容:
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)
<?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 数据改为方法参数,实现动态生成:
public static File generateXmlFile(String jsonData, String filePath) {// 替换固定JSON和路径为参数File outputFile = new File(filePath);// ...
}
异常处理:根据业务需求添加自定义异常(如文件写入权限检查)
4
此方案符合 XML 文件标准格式(含声明头和 UTF-8 编码),并通过 JDOM 的格式化输出保证可读性。返回的 File 对象可直接用于后续读写操作
1
3
6
。
