java 解析 xml 字符串转换为实体,实体转换为 xml 字符串

java 解析 xml 字符串转换为实体,实体转换为 xml 字符串

1. XmlCommonUtil工具类代码如下:
c 复制代码
import javax.xml.bind.JAXBContext;
import javax.xml.bind.Marshaller;
import javax.xml.bind.Unmarshaller;

/**
 * XmlCommonUtil类用于XML字符串和对象之间的转换以及读取文件操作
 */
public class XmlCommonUtil {

    /**
     * 将XML字符串转换为指定类的对象
     *
     * @param xml   XML字符串
     * @param clazz 目标类的Class对象
     * @return 转换后的对象
     */
    public static Object convertXmlStrToObject(String xml, Class clazz) throws Exception {
        JAXBContext context = JAXBContext.newInstance(clazz);
        Unmarshaller unmarshaller = context.createUnmarshaller();
        StringReader reader = new StringReader(xml);
        return unmarshaller.unmarshal(reader);
    }

    /**
     * 将实体对象转换为XML字符串
     *
     * @param obj 实体对象
     * @return 转换后的字符串
     */
    public static String convertObjectToXml(Object obj) throws Exception {
        StringWriter sw = new StringWriter();
        JAXBContext context = JAXBContext.newInstance(obj.getClass());
        Marshaller marshaller = context.createMarshaller();
        marshaller.setProperty(Marshaller.JAXB_FORMATTED_OUTPUT, Boolean.TRUE);
        marshaller.marshal(obj, sw);
        return sw.toString();
    }
}

2. 模拟资源文件数据SqlList.xml:
c 复制代码
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<sqls>
    <sql>
        SELECT 1
        WHERE 1 = 1
    </sql>
    <sql>
        SELECT 2
        WHERE 2 = 2
    </sql>
</sqls>

3. 实体类SqlXml代码如下:
c 复制代码
import javax.xml.bind.annotation.XmlElement;
import javax.xml.bind.annotation.XmlRootElement;
import javax.xml.bind.annotation.XmlType;
/**
 * SqlXml类用于表示XML中的sql元素
 */
@XmlRootElement(name = "sqls")
@XmlType(propOrder = {"sql"})
public class SqlXml {
    private List<String> sql;

    @XmlElement(name = "sql")
    public List<String> getSql() {
        return sql;
    }

    public void setSql(List<String> sql) {
        this.sql = sql;
    }

    @Override
    public String toString() {
        return "SqlXml{" +
                "sql=" + sql +
                '}';
    }
}

4. main方法代码测试:
c 复制代码
    public static void main(String[] args) throws Exception{
        // 读取指定文件中的XML内容
        String xmlStr = readFile("sql/SqlList.xml");

        // 将XML字符串转换为SqlXml对象
        SqlXml sqlXml = (SqlXml)convertXmlStrToObject(xmlStr, SqlXml.class);
        System.out.println(sqlXml);

        // 将SqlXml对象转换为XML字符串
        xmlStr = convertObjectToXml(sqlXml);
        System.out.println(xmlStr);
    }

    /**
     * 读取指定文件并返回文件内容
     *
     * @param file 文件路径
     * @return 文件内容字符串
     */
    public static String readFile(String file) {
        StringBuffer sb = null;
        try {
            InputStream inputStream = Thread.currentThread().getContextClassLoader().getResourceAsStream(file);
            BufferedReader bufferedReader = new BufferedReader(new InputStreamReader(inputStream));
            sb = new StringBuffer();
            String line = "";
            while ((line = bufferedReader.readLine()) != null) {
                sb.append(line + "\r\n");
            }
            bufferedReader.close();
        } catch (Exception e) {
            e.printStackTrace();
        }
        return sb.toString();
    }

5. 执行结果:
c 复制代码
SqlXml{sql=[
        SELECT 1
        WHERE 1 = 1
    , 
        SELECT 2
        WHERE 2 = 2
    ]}
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<sqls>
    <sql>
        SELECT 1
        WHERE 1 = 1
    </sql>
    <sql>
        SELECT 2
        WHERE 2 = 2
    </sql>
</sqls>


Process finished with exit code 0

相关推荐
前方一片光明21 小时前
SQL SERVER——生成sql:删除所有log表中,user_name是某用户的数据
数据库·sql·oracle
BestAns1 天前
一文带你吃透 Java 反射机制
java·后端
Gauss松鼠会1 天前
【GaussDB】在duckdb中查询GaussDB的数据
数据库·sql·database·gaussdb
沐知全栈开发1 天前
HTML5 浏览器支持
开发语言
wasp5201 天前
AgentScope Java 核心架构深度解析
java·开发语言·人工智能·架构·agentscope
WHOVENLY1 天前
【javaScript】- 笔试题合集(长期更新,建议收藏,目前已更新至31题)
开发语言·前端·javascript
智算菩萨1 天前
高效多模态大语言模型:从统一框架到训练与推理效率的系统化理论梳理
大数据·人工智能·多模态
2501_916766541 天前
【Springboot】数据层开发-数据源自动管理
java·spring boot·后端
hzp6661 天前
新兴存储全景与未来架构走向
大数据·大模型·llm·aigc·数据存储
慌糖1 天前
流-为序列化解释
开发语言