收到数据后先strstr(buffer,"<?xml version=\"1.0\" encoding=\"UTF-8\"?>")
如果返回的是NULL则表示没有这段 退出
buffer是你收到的数据起始地址
/* 前段时间恰好做过类似的东西,代码可以给你参考下。* Xml配置见最后
*/
typedef struct SrcFileFmt
{
int ColID
char ColCode[64] /* 字段英文名称 */
char ColName[128] /* 字段中文名称*/
char ColType[20] /* 字段类型(包含长度) */
char ColComment[128] /* 字段描述 */
}SrcFileFmt
int main(int argc, char **argv)
{
SrcFileFmt SrcFileFmt[128]
int iNum = -1
if ( 2 > argc )
{
printf("Usage: %s SrcXmlFile\n", argv[0])
return -1
}
iNum = parseSourceCfg(SrcCfgFile, SrcFileFmt)
if (iNum == -1)
{
return -1
}
return 0
}
/* 调用此函数后,xml文件的内容会被存储到结构体数组SrcFileFmt srcfilefmt[]中
* 此函数依赖于libxml2-2.9.2.tar.xz
*/
int parseSourceCfg(char *FileName, SrcFileFmt srcfilefmt[])
{ /* 解析源文件xml,FileName 为源xml文件名 */
xmlDocPtr doc
xmlNodePtr cur, root
char sFileName[64] = {'\0'}
int cnt = 0
if (FileName == NULL)
{
return -1
}
sprintf(sFileName, "%s.xml", FileName)
doc = xmlParseFile(sFileName)
if (doc == NULL)
{
return -1
}
root = xmlDocGetRootElement(doc)
if (root == NULL) {
xmlFreeDoc(doc)
return(-1)
}
if (xmlStrcmp(root->name, (const xmlChar *) "SrcRoot"))
{
xmlFreeDoc(doc)
return -1
}
cur = root->xmlChildrenNode
while (cur != NULL)
{
if ((!xmlStrcmp(cur->name, (const xmlChar *)"Column")))
{
xmlChar *key
xmlNodePtr cur_sub = cur
cur_sub = cur_sub->xmlChildrenNode
while (cur_sub != NULL)
{
if ((!xmlStrcmp(cur_sub->name, (const xmlChar *)"ColID"))) {
key = xmlNodeListGetString(doc, cur_sub->xmlChildrenNode, 1)
killblank((char*)key)
srcfilefmt[cnt].ColID = atoi((char*)key)
xmlFree(key)
}
if ((!xmlStrcmp(cur_sub->name, (const xmlChar *)"ColCode"))) {
key = xmlNodeListGetString(doc, cur_sub->xmlChildrenNode, 1)
killblank((char*)key)
strcpy(srcfilefmt[cnt].ColCode, (char*)key)
xmlFree(key)
}
else if ((!xmlStrcmp(cur_sub->name, (const xmlChar *)"ColName"))) {
key = xmlNodeListGetString(doc, cur_sub->xmlChildrenNode, 1)
killblank((char*)key)
strcpy(srcfilefmt[cnt].ColName, (char*)key)
xmlFree(key)
}
else if ((!xmlStrcmp(cur_sub->name, (const xmlChar *)"ColType"))) {
key = xmlNodeListGetString(doc, cur_sub->xmlChildrenNode, 1)
killblank((char*)key)
strcpy(srcfilefmt[cnt].ColType, (char*)key)
xmlFree(key)
}
else if ((!xmlStrcmp(cur_sub->name, (const xmlChar *)"ColComment"))) {
key = xmlNodeListGetString(doc, cur_sub->xmlChildrenNode, 1)
killblank((char*)key)
strcpy(srcfilefmt[cnt].ColComment, (char*)key)
xmlFree(key)
}
cur_sub = cur_sub->next
}
cnt++
}
cur = cur->next
}
xmlFreeDoc(doc)
return cnt
}
<SrcRoot>
<Column>
<ColID>1</ColID>
<ColCode>kmh</ColCode>
<ColName>字段1</ColName>
<ColType>VARCHAR(11)</ColType>
</Column>
<Column>
<ColID>2</ColID>
<ColCode>dfkmh</ColCode>
<ColName>字段2</ColName>
<ColType>VARCHAR(11)</ColType>
</Column>
<Column>
<ColID>3</ColID>
<ColCode>hbh</ColCode>
<ColName>字段3</ColName>
<ColType>INTEGER(10)</ColType>
</Column>
</SrcRoot>
//////////////////////////////////////////////////// /// 说明 : 解析XML文件 返回XML的根节点 /// 参数 : /// : xml xml文件路径 [in] /// : buffer 供解析用的缓冲 [in] /// : buffer_len 缓冲大小(单位:字节) [in] /// : error_reason 执行出错时保存错误原因 [in] /// : root XML的根节点 [out] /// 返回 : 成功 返回 失败返回 /// 说明 : /// : 问 :供解析用的缓冲应该取多大比较合适呢? /// : 答 :供解析用的缓冲主要用来存放XML树 所以 buffer_len >= (XML文件的大小) * 即可 /// :
int mini_parse_xml (char* xml char* buffer int buffer_len char error_reason[ ] MINI_XML_NODE** root)
//////////////////////////////////////////////////// /// 说明 : 查找特定节点的子节点 /// 参数 : /// : father 父结点 [in] /// : name 子孩子节点名 [in] /// : child 子节点 [out]
int mini_find_child (MINI_XML_NODE* father char* name MINI_XML_NODE** child)
//////////////////////////////////////////////////// /// 说明 : 查找特定节点的属性值 /// 参数 : /// : node 节点 [in] /// : name 属性名 [in] /// : value 属性值 [out]
int mini_find_attribute (MINI_XML_NODE* node char* name char** value)
//////////////////////////////////////////////////// /// 说明 : 打印XML树 供调试用 int mini_print_tree (MINI_XML_NODE* root int layer)
#if defined (__cplusplus) || defined (c_plusplus) } #endif #endif
lishixinzhi/Article/program/net/201311/14908