智能路由器C代码调用uci的API读openwrt配置文件指南二

Posted arvik

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了智能路由器C代码调用uci的API读openwrt配置文件指南二相关的知识,希望对你有一定的参考价值。

【智能路由器】系列文章连接
http://blog.csdn.net/u012819339/article/category/5803489


介绍

本篇博客是对 【智能路由器】C代码调用uci的API读openwrt配置文件指南 文章的补充

网上依旧有一些网友有C代码调用uci设置的需求,这里整理了arvik以前项目中编写的c语言调用uci的两个接口,供大家在项目中参考使用


接口

接口 uci_set_str
原型:

/*
设置uci配置项 , 保存并且提交更改到文件  
arg: 设置参数
    eg. 
        wireless.@wifi-iface[0]=wifi-iface
        wireless.radio0.path=platform/ar934x_wmac
        wireless.radio0.newabc=arvik
返回值:
成功返回UCI_OK, 失败返回其它值
*/
int uci_set_str(const char *arg);

C代码调用uci分别设置wireless.@wifi-iface[0]=wifi-ifacewireless.radio0.path=platform/ar934x_wmac, 使用方法:

 // 以下函数相当于执行 uci set wireless.@wifi-iface[0]=wifi-iface 再加上  uci commit wireless.@wifi-iface[0] 两个命令
uci_set_str("wireless.@wifi-iface[0]=wifi-iface");

//以下函数相当于执行 uci set wireless.radio0.path=platform/ar934x_wmac 再加上  uci commit wireless.radio0.path=platform/ar934x_wmac 两个命令
uci_set_str("wireless.radio0.path=platform/ar934x_wma");

接口 uci_get_str
原型:

/*
获取uci配置项  
arg: 获取该参数下的值
    eg. 
        wireless.@wifi-iface[0]
        wireless.radio0.path
out: 获取的值存储区

返回值:
成功返回UCI_OK, 失败返回其它值
*/
int uci_get_str(const char *arg, char *out);

C代码调用uci获取wireless.radio0.path, 使用方法:

int ret = -1;
char buf[1024]=0;

//以下函数相当于执行命令行 uci get wireless.radio0.path
ret = uci_get_str("wireless.radio0.path", buf);  // buf中的值就是获取到的对应的值,如platform/ar934x_wmac
if(ret != UCI_OK)

	......   // uci get error



源代码:

将以下文件包含进工程编译即可方便使用接口

ucili.c文件:

/**********************************************************
*  file: ucili.h
*  purpose: uci c call
*  author: arvik
*  blog: http://blog.csdn.net/u012819339
*  email: 1216601195@qq.com
***********************************************************/

#include <string.h>
#include <stdlib.h>
#include <unistd.h>

#include "ucili.h"

static int uci_get_value(struct uci_option *o, char *out)

	struct uci_element *e;
    const char *delimiter = " ";
	bool sep = false;

	switch(o->type) 
	case UCI_TYPE_STRING:
        strcpy(out, o->v.string);
		break;
	case UCI_TYPE_LIST:
		uci_foreach_element(&o->v.list, e) 
            if(sep)
                strcat(out, delimiter);
            strcat(out, e->name);
			sep = true;
		
		break;
	default:
		return UCI_ERR_INVAL;
		break;
	

    return UCI_OK;



int uci_get_str(const char *arg, char *out)

    struct uci_context *ctx;
    struct uci_element *e;
	struct uci_ptr ptr;
	int ret = UCI_OK;
    char *name = NULL;

    if(arg == NULL || out == NULL) return UCI_ERR_INVAL;
    name = strdup(arg);
    if(name == NULL) return UCI_ERR_INVAL;

    ctx = uci_alloc_context();
	if (!ctx) 
        free(name);
		return UCI_ERR_MEM;
	

    if (uci_lookup_ptr(ctx, &ptr, name, true) != UCI_OK) 
        uci_free_context(ctx);
        free(name);
		return UCI_ERR_NOTFOUND;
	  

    if(UCI_LOOKUP_COMPLETE & ptr.flags)
    
        e = ptr.last;
        switch(e->type)
        
            case UCI_TYPE_SECTION:
                ret = UCI_ERR_INVAL;
            break;
            case UCI_TYPE_OPTION:
                ret = uci_get_value(ptr.o, out);
            break;
            default:
                ret = UCI_ERR_NOTFOUND;
            break;
        
    
    else
        ret = UCI_ERR_NOTFOUND;

    uci_free_context(ctx);
    free(name);
    return ret;


int uci_set_str(const char *arg)

    struct uci_context *ctx;
    struct uci_element *e;
	struct uci_ptr ptr;
	int ret = UCI_OK;
    char *name = NULL;

    if(arg == NULL) return UCI_ERR_INVAL;
    name = strdup(arg);
    if(name == NULL) return UCI_ERR_MEM;

    ctx = uci_alloc_context();
	if (!ctx) 
        free(name);
		return UCI_ERR_MEM;
	

    if (uci_lookup_ptr(ctx, &ptr, name, true) != UCI_OK) 
        uci_free_context(ctx);
        free(name);
		return UCI_ERR_NOTFOUND;
	

    ret = uci_set(ctx, &ptr);
    if(ret != UCI_OK)
    
        uci_free_context(ctx);
        free(name);
        return ret;
    

    ret = uci_save(ctx, ptr.p);
    if(ret != UCI_OK)
    
        uci_free_context(ctx);
        free(name);
        return ret;
    

    ret = uci_commit(ctx, &ptr.p, false);
    if(ret != UCI_OK)
    
        uci_free_context(ctx);
        free(name);
        return ret;
    

    uci_free_context(ctx);
    free(name);
    return ret;


ucili.h文件:

/**********************************************************
*  file: ucili.h
*  purpose: uci c call
*  author: arvik
*  blog: http://blog.csdn.net/u012819339
*  email: 1216601195@qq.com
***********************************************************/

#ifndef _UCILI_H_
#define _UCILI_H_

#include "uci.h"


/*
设置uci配置项 , 保存并且提交更改到文件  
arg: 设置参数
    eg. 
        wireless.@wifi-iface[0]=wifi-iface
        wireless.radio0.path=platform/ar934x_wmac
        wireless.radio0.newabc=arvik
返回值:
成功返回UCI_OK, 失败返回其它值
*/
int uci_set_str(const char *arg);

/*
获取uci配置项  
arg: 获取该参数下的值
    eg. 
        wireless.@wifi-iface[0]
        wireless.radio0.path
out: 获取的值存储区

返回值:
成功返回UCI_OK, 失败返回其它值
*/
int uci_get_str(const char *arg, char *out);



#endif 

【智能路由器】系列文章连接
http://blog.csdn.net/u012819339/article/category/5803489

以上是关于智能路由器C代码调用uci的API读openwrt配置文件指南二的主要内容,如果未能解决你的问题,请参考以下文章

智能路由器C代码调用uci的API读openwrt配置文件指南二

智能路由器C代码调用uci的API读openwrt配置文件指南

Openwrt下C调用UCI API

OpenWRT UCI API的使用

OpenWrt防火墙配置(极路由)

智能路由器-OpenWRT 系列六 (远程迅雷离线下载)