使用GHashTable和strsep()函数解析http报文

来源:互联网 发布:算法导论 中文版 mobi 编辑:程序博客网 时间:2024/04/28 14:25

#include <stdlib.h>

#include <glib.h>


#define FIELD_NAME_ARRAY_LENGHT  8

field_name_array[FIELD_NAME_ARRAY_LENGHT] = {"wd", "rsv_spt", "issp", "rsv_bp", "ie", "tn", "n", "inputT"};


int main()

{

    char data[1024] = "?wd=getenv&rsv_spt=1&issp=1&rsv_bp=0&ie=utf-8&tn=baiduhome_pg&n=2&inputT=1186";       


     //解析报文        

    char *tp = data, *p, *key_array, *value_array;

 GHashTable *table = NULL;

    table = g_hash_table_new(g_str_hash, g_str_equal);  

    

 //分解字符串为一组字符串。从tp指向的位置起向后扫描,遇到'&'后,将此字符替换为NULL,返回tp指向的地址。

    while(NULL != (p = strsep(&tp, "&")) ) 
    {
        key_array = strsep(&p, "=");
        value_array = p;
        g_hash_table_insert(table, key_array, value_array); //将两次strsep()解析出来的key-value对插入hashtable中
    }


    //取出key-value
    char *field_value_array[FIELD_NAME_ARRAY_LENGHT] = {NULL};
    for(i = 0; i < FIELD_NAME_ARRAY_LENGHT; i++)
    {
          g_hash_table_lookup_extended(table, field_name_array[i], NULL, (gpointer *)&field_value_array[i]); //从hashtable中取出key为field_name_array[i]的value值

    }

    return 0;

}


原创粉丝点击