【XML生成】根据JSON格式化的报文,动态生成XML

无需创建实体对象,根据属性动态生成XML方式

java 复制代码
	import org.w3c.dom.Document;
	import org.w3c.dom.Element;
	import java.io.File;
	import javax.xml.parsers.DocumentBuilder;
	import javax.xml.parsers.DocumentBuilderFactory;
	import javax.xml.transform.OutputKeys;
	import javax.xml.transform.Transformer;
	import javax.xml.transform.TransformerFactory;
	import javax.xml.transform.dom.DOMSource;
	import javax.xml.transform.stream.StreamResult;

	//根据动态属性,生成XML文件
    public static void generateXmlFromMap(Map<String, String> data, String rootName, String filePath) {
        try {
            // 创建 XML 文档
            DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
            DocumentBuilder builder = factory.newDocumentBuilder();
            Document doc = builder.newDocument();

            // 创建根节点
            Element root = doc.createElement(rootName);
            doc.appendChild(root);

            // 遍历 Map,每个 key 作为标签名,value 作为文本内容
            for (Map.Entry<String, String> entry : data.entrySet()) {
                String tagName = entry.getKey();
                String value = entry.getValue() == null ? "" : entry.getValue().trim();

                Element element = doc.createElement(tagName);
                element.setTextContent(value);
                root.appendChild(element);
            }

            // 写出到文件
            TransformerFactory transformerFactory = TransformerFactory.newInstance();
            Transformer transformer = transformerFactory.newTransformer();
            transformer.setOutputProperty(OutputKeys.ENCODING, "UTF-8");
            transformer.setOutputProperty(OutputKeys.INDENT, "yes"); // 美化格式
            transformer.transform(new DOMSource(doc), new StreamResult(new File(filePath)));

            System.out.println("XML 文件已生成:" + filePath);

        } catch (Exception e) {
            e.printStackTrace();
        }
    }

    // 测试
    public static void main(String[] args) {
        // 模拟从 JSON
        Map<String, String> data = new HashMap<>();
        data.put("archiveNumber", "JZ-2025-0000");
        data.put("archiveDate", "2025-11-20");
        data.put("operUser", "张三");
        data.put("archiveTitle", "2025年11月记账凭证");
        data.put("creater", "张三");

        // 生成 XML
        generateXmlFromMap(data, "Archive", "archive.xml");
    }
相关推荐
逍遥德44 分钟前
Java编程高频的“踩坑点”-01:fastjson.JSON 转换时泛型擦除问题
java·spring boot·spring·系统架构·json
sa100271 天前
京东评论 API 实战:JSON 数据结构、字段含义与解析技巧
前端·数据结构·json
查拉图斯特拉面条1 天前
JMeter 实战技巧:JSON 数组筛选指定对象并剔除首尾大括号
jmeter·json
霸道流氓气质1 天前
Spring AI 结构化输出 Agent 实战:让大模型返回精准 JSON
人工智能·spring·json
查拉图斯特拉面条1 天前
JMeter 实战:JSON 响应中文节点 + 数值精准断言(附真实接口案例)
jmeter·json
Rooting++2 天前
package.json三种依赖的区别
vue.js·json
曹牧2 天前
C#:DataGridView控件中展示JSON内容
开发语言·c#·json
howard20053 天前
4.4 Spark SQL数据源 - JSON
json·spark sql数据源
灰子学技术3 天前
Envoy gRPC-JSON 转码器功能实现分析
json
夜雪闻竹3 天前
Cursor 的 state.vscdb 解析踩坑记
json·aigc·ai编程