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

相关推荐
hengzhepa7 分钟前
ElasticSearch备考 -- Async search
大数据·学习·elasticsearch·搜索引擎·es
哎呦没21 分钟前
大学生就业招聘:Spring Boot系统的架构分析
java·spring boot·后端
Kalika0-038 分钟前
猴子吃桃-C语言
c语言·开发语言·数据结构·算法
_.Switch40 分钟前
Python Web 应用中的 API 网关集成与优化
开发语言·前端·后端·python·架构·log4j
编程、小哥哥1 小时前
netty之Netty与SpringBoot整合
java·spring boot·spring
代码雕刻家1 小时前
课设实验-数据结构-单链表-文教文化用品品牌
c语言·开发语言·数据结构
一个闪现必杀技1 小时前
Python入门--函数
开发语言·python·青少年编程·pycharm
Fan_web1 小时前
jQuery——事件委托
开发语言·前端·javascript·css·jquery
龙图:会赢的1 小时前
[C语言]--编译和链接
c语言·开发语言
GZ_TOGOGO1 小时前
【2024最新】华为HCIE认证考试流程
大数据·人工智能·网络协议·网络安全·华为