xml嵌套xml时的转移字符

使用场景

项目中,数据库升级工具,使用xml格式保存数据库升级脚本,格式如下:

<?xml version="1.0" encoding="iso-8859-1" ?>
<upgrade version="1.1">
    <sqls>
        <!-- 数据库升级脚本 -->
        <DML>
            UPDATE sysconfig SET strValue='' where nType=10023;
        </DML>
        <DDL DB="MysqL">
            ALTER TABLE device MODIFY COLUMN strPassword VARCHAR(256);
        </DDL>
        <DDL DB="sqlServer">
            ALTER TABLE device ALTER COLUMN strPassword VARCHAR(256);
        </DDL>
    </sqls>
</upgrade>

其中,关于此工具逻辑说明如下:
1. <DML><DDL> 分别对应DML和DDL类型的语句;
2. 如果sql语句有兼容性问题,需要分别标注数据库类型,此工具要兼容MysqLsql Server;
3. 直接执行sql语句是不需要对XML的特殊字符做转义的。

对于以下语句:
UPDATE sysconfig SET strValue=” where nType=10023;


当strValue=”的值为xml时,将涉及到xml嵌套的问题,需要对内嵌的xml特殊字符做转义。

解决方

需要转义的字符如下:

原字符 转义字符
< &lt;
> &gt;
" &quot;

特殊说明


但是,有些特殊情况下,要保留转移字符,需要对转移字符再次转义。
比如:&#13;字符,表示HTML的回车符号。在xml中会被忽略掉,因此需要分别对“&”、“#”、“;”做转义。最终应写为:&#38;&#35;13&#59;

参考资料

Html和Xml 文件中的特殊字符 需要转义
xml中回车的转义字符串是什么?该如何处理

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


php输出xml格式字符串
J2ME Mobile 3D入门教程系列文章之一
XML轻松学习手册
XML入门的常见问题(一)
XML入门的常见问题(三)
XML轻松学习手册(2)XML概念
xml文件介绍及使用
xml编程(一)-xml语法
XML文件结构和基本语法
第2章 包装类
XML入门的常见问题(二)
Java对象的强、软、弱和虚引用
JS解析XML文件和XML字符串详解
java中枚举的详细使用介绍
了解Xml格式
XML入门的常见问题(四)
深入SQLite多线程的使用总结详解
PlayFramework完整实现一个APP(一)
XML和YAML的使用方法
XML轻松学习总节篇