• window下libxml2的编译及使用


    libiconv 库编译
    1、去http://ftp.gnu.org/pub/gnu/libiconv/下载源码包,本文使用的是libiconv-1.15.tar.gz

    2、新建libiconv空的控制台工程
      (1)将下载的库中lib文件夹下的所有文件拷贝到工程目录下
      (2)将库中include文件夹下iconv.h.in文件重命名为iconv.h放在工程目录下
      (3)将拷贝到工程目录下的config.h.in重命名为config.h
      (4)将库中libcharset/lib/localcharset.c文件拷贝到工程目录下
      (5)将库中libcharset/include/localcharset.h.in文件重命名为localcharset.h放在工程目录下

    3、工程中添加现有项,将 iconv.c ,localcharset.c 添加到工程中.

    4、工程属性->C/C++ –>附加包含目录:$(ProjectDir);

    5、工程属性:常规->配置类型->静态库(.lib)

    6、修改文件中的BUG
      (1) iconv.h :
      1).删除掉所有的 @ 符号 (14处)
      2).修改25行: extern DLL_VARIABLE int _libiconv_version;改为 extern /*DLL_VARIABLE*/ int _libiconv_version;
      3).修改83行:extern size_t iconv (iconv_t cd, ICONV_CONST char* * inbuf, size_t *inbytesleft, char* * outbuf, size_t*outbytesleft);  改 为  extern size_t iconv (iconv_t cd, /*ICONV_CONST*/ char* * inbuf, size_t *inbytesleft, char* * outbuf, size_t *outbytesleft);

    (2)localcharset.c:
          注释掉76行:  # include "configmake.h" 
      468行 : sprintf  改为 sprintf_s(buf, 2 + 10 + 1, "CP%u", GetACP());


    7、编译,并将编译之后的libIconv.lib和iconv.h拷贝出来


    libxml2库编译
    1、下载libxml2,官网是:http://www.xmlsoft.org/downloads.html,下载地址是:ftp://gd.tuwien.ac.at/pub/libxml/.版本是:libxml2-sources-2.9.7.tar.gz

    2、解压文件到目录D:libxml2-2.9.7


    3、新建文件夹D:xml把安装libiconv生成的iconv.lib、iconv.h文件夹拷贝到xml文件夹下的lib和include文件夹。


    4、打开 Visual Studio 2010 Command Prompt程序


    5、cd D:libxml2-2.9.7win32


    6、cscript configure.js compiler=msvc prefix=D:xml include=D:xmlinclude lib=D:xmllib debug=yes


    7、nmake /f Makefile.msvc


    8、nmake /f Makefile.msvc install
    完成后即可在D:xmlin文件夹下看到生成的库即程序

    测试用例

    #include <stdio.h>
    #include <libxml/parser.h>
    #include <libxml/tree.h>
    #include <iostream>
    #include "xml.h"
    using namespace std;
    #pragma comment(lib,"./libxml2/lib/libxml2.lib")
    void creatXML()
    {
        //定义文档和节点指针
    
        xmlDocPtr doc = xmlNewDoc(BAD_CAST"1.0");
    
        xmlNodePtr root_node = xmlNewNode(NULL,BAD_CAST"root");
    
        //设置根节点
    
        xmlDocSetRootElement(doc,root_node);
    
        //在根节点中直接创建节点
    
        xmlNewTextChild(root_node, NULL, BAD_CAST "newNode1", BAD_CAST "newNode1 content");
    
        xmlNewTextChild(root_node, NULL, BAD_CAST "newNode2", BAD_CAST "newNode2 content");
    
        xmlNewTextChild(root_node, NULL, BAD_CAST "newNode3", BAD_CAST "newNode3 content");
    
        //创建一个节点,设置其内容和属性,然后加入根结点
    
        xmlNodePtr node = xmlNewNode(NULL,BAD_CAST"node2");
    
        xmlNodePtr content = xmlNewText(BAD_CAST"NODE CONTENT");
    
        xmlAddChild(root_node,node);
    
        xmlAddChild(node,content);
    
        xmlNewProp(node,BAD_CAST"attribute",BAD_CAST "yes");
    
        //创建一个儿子和孙子节点
    
        node = xmlNewNode(NULL, BAD_CAST "son");
    
        xmlAddChild(root_node,node);
    
        xmlNodePtr grandson = xmlNewNode(NULL, BAD_CAST "grandson");
    
        xmlAddChild(node,grandson);
    
        xmlAddChild(grandson, xmlNewText(BAD_CAST "This is a grandson node"));
    
        //存储xml文档
    
        int nRel = xmlSaveFile("CreatedXml.xml",doc);
    
        if (nRel != -1)
    
        {
            cout<<"一个xml文档被创建,写入"<<nRel<<"个字节"<<endl;
        }
        //释放文档内节点动态申请的内存
        xmlFreeDoc(doc);
    }
    
    void readXML()
    {
        xmlDocPtr doc;           //定义解析文档指针
        xmlNodePtr curNode;      //定义结点指针(你需要它为了在各个结点间移动)
        xmlChar *szKey;          //临时字符串变量
        char *szDocName;
     
        szDocName =  "./CreatedXml.xml";
        doc = xmlReadFile(szDocName,"GB2312",XML_PARSE_RECOVER); //解析文件
        //检查解析文档是否成功,如果不成功,libxml将指一个注册的错误并停止。
        //一个常见错误是不适当的编码。XML标准文档除了用UTF-8或UTF-16外还可用其它编码保存。
        //如果文档是这样,libxml将自动地为你转换到UTF-8。更多关于XML编码信息包含在XML标准中.
        if (NULL == doc)
        { 
            cout<<"Document not parsed successfully";    
                return ;
        }
        curNode = xmlDocGetRootElement(doc); //确定文档根元素
        /*检查确认当前文档中包含内容*/
        if (NULL == curNode)
        {
            cout<<"empty document";
                xmlFreeDoc(doc);
            return  ;
        }
        /*在这个例子中,我们需要确认文档是正确的类型。“root”是在这个示例中使用文档的根类型。*/
        if (xmlStrcmp(curNode->name, BAD_CAST "root"))
        {
            cout<<"document of the wrong type, root node != root";
            xmlFreeDoc(doc);
            return ;
        }
        curNode = curNode->xmlChildrenNode;
        xmlNodePtr propNodePtr = curNode;
        while(curNode != NULL)
        {
            //取出节点中的内容
            if ((!xmlStrcmp(curNode->name, (const xmlChar *)"newNode1")))
            {
                szKey = xmlNodeGetContent(curNode);
                cout<<"newNode1"<<szKey;
                    xmlFree(szKey);
            }
            //查找带有属性attribute的节点
            if (xmlHasProp(curNode,BAD_CAST "attribute"))
            {
                propNodePtr = curNode;
            }
            curNode = curNode->next;
        }
        //查找属性
        xmlAttrPtr attrPtr = propNodePtr->properties;
        while (attrPtr != NULL)
        {
            if (!xmlStrcmp(attrPtr->name, BAD_CAST "attribute"))
            {
                xmlChar* szAttr = xmlGetProp(propNodePtr,BAD_CAST "attribute");
                cout<<"get attribute = "<<szAttr<<endl;
                xmlFree(szAttr);
            }
            attrPtr = attrPtr->next;
        }
        xmlFreeDoc(doc);
    }
     
    int main()
    {
        creatXML();
    }
    xml.cpp
    海阔凭鱼跃,天高任鸟飞。
  • 相关阅读:
    docker的应用部署
    docker容器的数据卷
    找到最终的安全状态 深搜
    park和unpark方法详解
    docker容器相关命令
    docker鏡像相關命令
    join方法底层实现
    Elasticsearch启动过程错误汇总
    MySQL 8.0.12 报错The table does not comply with the requirements by an external plugin. (errno 3098)
    docker login 密码查看和加密保存
  • 原文地址:https://www.cnblogs.com/chenshikun/p/9124606.html
Copyright © 2020-2023  润新知