Libxml2 编译

本文深入探讨了Libxml2的特性及其在Linux和Windows平台上的编译与安装方法,重点展示了如何利用Libxml2 API生成XML文档,包括中文处理、Xpath解析、DTD验证等功能,并提供了代码实例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Libxml2 是一个xml c语言版的解析器,本来是为Gnome项目开发的工具,是一个基于MIT License的免费开源软件。它除了支持c语言版以外,

还支持c++、PHP、Pascal、Ruby、Tcl等语言的绑定,能在Windows、Linux、Solaris、MacOsX等平台上运行。

Libxml2主要的优点有:

1. 安装、使用比较简单,容易入门;

2. 支持的编码格式较多,能很好的解决中文问题(使用一个很简单的编码转换函数);

3. 支持Xpath解析(这点对于任意定位xml文档中的节点还是很有用的哦);

4. 支持Well-formed 和valid验证,具体而言支持DTD验证,Schema验证功能正在完善中(目前多数解析

器都还不完全支持shema验证功能);

5. 支持目前通用的Dom、Sax方式解析等等。

Libxml2的在linux下的编译安装:

1. 从xmlsoft站点或ftp(ftp.xmlsoft.org)站点下载libxml压缩包(libxml2-xxxx.tar.gz)

2. 对压缩包进行解压缩: tar xvzf libxml2-xxxx.tar.gz

3. 进入解压缩后的文件夹中运行: ./configure && make && make install 即可。

Libxml2的在windows下的编译安装:

以libxml2-2.6.30为例,解压后,打开cmd窗口,进入libxml2-2.6.30目录:

1. cd win32

2. cscript configure.js compiler=msvc debug=yes

3. nmake /f Makefile.msvc(进入bin.msvc/目录就可以看到生成的库文件:libxml2.dll libxml2.lib

libxml2_a.lib libxml2_a_dll.lib)

4. nmake install, 因为第二步没有指定prefix,所以这里会在win32目录下生成三个目录include/lib/bin,

将这三个目录copy到vc的相应目录(C:\Program Files\Microsoft Visual Studio\VC98)既可以在vc

的工程中直接使用libxml2的头文件和库。

使用libxml2生成xml文档

头文件:

#include "libxml\xmlwriter.h"

#include "libxml\encoding.h"

库文件:libxml2.dll libxml2.lib

代码实例:

因为我的程序中都是UTF-16编码,所以根据testWriter.c中的ConvertInput函数实现的

utf-16到utf8的转换函数:

/**

* ConvertInput:

* @in: string in a given encoding

* @encoding: the encoding used

*

* Converts UTF-16LE@in into UTF-8 for processing with libxml2 APIs

*

* Returns the converted UTF-8 string, or NULL in case of error.

*/

xmlChar *ConvertInput(const wchar_t *in, const char *encoding)

{

xmlChar *out;

int ret;

int size;

int out_size;

int temp;

xmlCharEncodingHandlerPtr handler;

if ( in == 0 )

return (0);

handler = xmlFindCharEncodingHandler(encoding);

if ( !handler )

{

TRACE("ConvertInput: no encoding handler found for '%s'\n",

encoding ? encoding : "");

return (0);

}

/*size为UTF-16编码的字符串字节数*/

size = (int) (wcslen(in) + 1)* sizeof(wchar_t) ;

out_size = size * 2;

out = (unsigned char *) xmlMalloc((size_t) out_size);

if ( out != 0 )

{

ret = handler->input(out, &out_size, (const xmlChar *) in, &size);

if ( (ret < 0) )

{

TRACE("ConvertInput: conversion wasn't successful.\n");

xmlFree(out);

out = 0;

}

}

else

{

TRACE("ConvertInput: no mem\n");

}

return (out);

}

使用xmlWriter APIs写一个xml文档,代码如下:

int rc;

xmlTextWriterPtr writer;

xmlDocPtr doc;

xmlChar *tmp;

/* 创建一个新的xml Writer,无压缩*/

writer = xmlNewTextWriterDoc(&doc, 0);

if (writer == NULL) { return; }

/* 文档声明部分 */

rc = xmlTextWriterStartDocument(writer, NULL, "UTF-16", NULL);

if (rc < 0) { return; }

/* 创建第一个元素"EXAMPLE"作为文档的根元素. */

rc = xmlTextWriterStartElement(writer, (xmlChar*)"EXAMPLE");

if (rc < 0) { return; }

/* 为EXAMPLE增加一个注释作为子元素,因为xmlTextWriter函数都使用

* UTF-8的编码,所以这里对中文注释做一个编码转换*/

/* 假设wchar_t cmt 指向 "这是一个EXAMPLE元素的注释" 的UTF-16串*/

tmp = ConvertInput(cmt, "UTF-16");

rc = xmlTextWriterWriteComment(writer, tmp);

if (rc < 0) { return; }

/*增加一个新的子元素ORDER*/

rc = xmlTextWriterStartElement(writer, (xmlChar*)"ORDER")

if (rc < 0) { return; }

/*为ORDER增加一个子元素,*/

rc = xmlTextWriterWriteFormatElement(writer, (xmlChar*)"NO", "%d",20);

/*结束子元素ORDER,直接调用下面的函数即可*/

rc = xmlTextWriterEndElement(writer);

/*结束元素EXAMPLE*/

rc = xmlTextWriterEndElement(writer);

/*释放xmlWriter的相关资源*/

xmlFreeTextWriter(writer);

/*写XML文档(doc)到文件*/

xmlSaveFileEnc(file, doc, MY_ENCODING);

xmlFreeDoc(doc);

效果:

<?xml version="1.0" encoding="UTF-16"?>

<EXAMPLE>

<!--这是一个EXAMPLE元素的注释-->

<ORDER>

<NO>20</NO>

</ORDER>

</EXAMPLE>


### 回答1: Libxml2是一个用于解析XML文档的开源软件库,它支持XML1.0、XML的命名空间、XML Schema以及XSLT等。在Libxml2中,sax1是一种基于事件的XML解析器,它可以逐个读取XML文档中的每个元素,并在解析时触发事件,从而达到解析XML文档的目的。 要编译sax1,请按照以下步骤操作: 1.在终端中打开libxml2的源代码地址。 2.使用命令./configure --with-sax1来启用sax1编译选项。这个命令将在编译时添加--with-sax1选项,以便将sax1解析器链接到libxml2库中。 3.执行make命令以编译libxml2。 4.执行make install命令以安装libxml2。 5.在你的应用程序中包含libxml2头文件,并连接到libxml2库,以便使用sax1解析器来解析你的XML文档。 需要注意的是,在使用sax1解析器时,你需要创建一个回调函数来处理解析事件。具体实现可以参考libxml2官方文档中的相关示例。同时,建议使用glib库来管理内存和错误处理,以避免内存泄漏和运行时错误。 ### 回答2libxml2是一个XML C解析库,其中包含了各种所需的工具和函数。SAX(Simple API for XML)是一种解析XML的方法,基于解析器和事件驱动模型,适用于大型XML文档。对于某些应用程序来说,使用SAX可以比DOM(Document Object Model)更高效地解析XML文档。 要编译libxml2的SAX1模块,需要遵循以下步骤: 1. 确认安装了libxml2库及其开发文件(libxml2-dev或xml2-dev)。可以在终端中使用以下命令进行检查: ``` dpkg -s libxml2-dev ``` 2. 下载libxml2源代码,可以在http://xmlsoft.org/sources/ 找到最新的版本。 3. 解压缩源代码,进入源代码文件夹,使用以下命令进行编译: ``` ./configure --with-sax1 && make ``` --with-sax1选项告诉编译器要编译SAX1模块。make命令会编译源代码并生成库文件。 4. 如果编译成功,可以在源代码文件夹下的.slibs或.libs文件夹中找到生成的库文件。 5. 编写程序时需要引用libxml/parser.h头文件,并链接编译生成的库文件。使用SAX解析XML文件时需要注册解析器回调函数,并在解析时触发这些回调函数。 总的来说,编译libxml2的SAX1模块需要先确认安装了相关开发文件,然后通过配置选项告诉编译器要编译SAX1模块,最后生成库文件并在程序中引用。 ### 回答3: libxml2是一款开源的XML解析器,支持SAX和DOM两种解析方式。其中SAX解析方式是基于事件驱动的,需要用户自定义解析处理函数来响应不同的XML事件,适合解析大型XML文件和流式数据。 要编译libxml2的sax1模块,需要安装libxml2的开发包和sax1的头文件。在Linux系统中,可使用以下命令安装: sudo apt-get install libxml2-dev 安装后,进入libxml2源代码目录,运行以下命令: ./configure --with-sax1 make make install 其中,--with-sax1参数用于启用sax1模块,make命令用于编译,make install命令用于安装。 在编译过程中,可能会遇到一些依赖项缺失的错误,需要根据提示安装相应的依赖包。编译成功后,就可以在代码中使用sax1模块来解析XML数据了。 总之,编译libxml2的sax1模块需要安装开发包、头文件和依赖项,并使用特定的命令启用和编译sax1模块。对于熟悉Linux操作的开发者来说,这个过程并不复杂。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值