其他分享
首页 > 其他分享> > c-Pugixml-使用前缀映射和不带前缀mappig解析名称空间

c-Pugixml-使用前缀映射和不带前缀mappig解析名称空间

作者:互联网

我有一个客户端应用程序,可以分析从2个不同服务器发送的xml响应.我称它们为服务器A和服务器B.

服务器A响应以下请求之一:

<?xml version="1.0" encoding="UTF-8"?>
    <D:multistatus xmlns:D="DAV:">
    <D:response>
    <D:href>/T12.txt</D:href>
    <D:propstat>
    <D:prop>
    <local-modification-time xmlns="urn:abc.com:webdrive">1389692809</local-modification-time>
    </D:prop>

    <D:status>HTTP/1.1 200 OK</D:status>

    </D:propstat>
</D:response>
</D:multistatus>

服务器B对请求之一进行响应,如下所示:

<?xml version="1.0" encoding="UTF-8"?>
    <D:multistatus xmlns:D="DAV:">
    <D:response>
    <D:href>/T12.txt</D:href>
    <D:propstat>
    <D:prop>
    <O:local-modification-time xmlns:O="urn:abc.com:webdrive">1389692809</O:local-modification-time>
    </D:prop>

    <D:status>HTTP/1.1 200 OK</D:status>

    </D:propstat>
</D:response>
</D:multistatus>

如果观察到这两个服务器之间的差异,则serverA不会发送名称空间和前缀之间的映射,而serverB会发送(请查看local-modification-time标签).如何编写通用的客户端解析逻辑,以通用方式处理这两种情况.任何示例代码都会有很大帮助.

谢谢,
-Sandeep

解决方法:

我认为最好的选择是忽略名称空间,并通过本地名称查找节点.
您可以使用XPath做到这一点:

node.select_single_node(".[local-name()='local-modification-time']")

或者您可以像这样使用C:

pugi::xml_node child_by_local_name(pugi::xml_node node, const char* name)
{
    for (pugi::xml_node child = node.first_child(); child; child = child.next_sibling())
    {
        if (strcmp(child.name(), name) == 0)
            return child;

        const char* colon = strchr(child.name(), ':');

        if (colon && strcmp(colon + 1, name) == 0)
            return child;
    }

    return pugi::xml_node();
}

标签:xml-deserialization,pugixml,c,xml,xml-parsing
来源: https://codeday.me/bug/20191012/1899923.html