CWMP開源代碼研究2——easycwmp安裝和學習


聲明:本文是對開源程序代碼學習和研究,嚴禁用於商業目的。 如有任何問題,歡迎和我交流。(企鵝號:408797506)

本文所有筆記和代碼可以到csdn下載:http://download.csdn.net/detail/eryunyong/9590036

一. linux上安裝

為了更好理解easycwmp運行機制和以及部署在各類linux內核的操作系統環境,我們選擇官網的第二種安裝方法。

(1)       linux系統:Ubuntu 12.04

(2)       安裝EasyCwmp所需要的依賴:(若安裝過程提示找不到安裝包,請到官網更新Ubuntu源:http://wiki.ubuntu.org.cn/%E6%BA%90%E5%88%97%E8%A1%A8)

libcurl :

libuci

json-c:可能會遇到版本問題,后附解決放案.

libubox

libubus

libmicroxml:下載地址 http://easycwmp.org/download/libmicroxml.tar.gz

1. general安裝

參考官網,在/opt/目錄下創建git和dev兩個目錄。並賦予用戶操作權限
為了省去sudo麻煩,后面所有操作可以直接使用root用戶進行安裝

2.  curl安裝

安裝說明:
這里暫時不安裝curl工具,因為我們需要用curl進行編程,所以重點會介紹如何在c程序里使用curl提供的API接口。
如果喜歡curl命令行工具,可以使用命令安裝: sudo apt-get install curl
后續如果有必要,再安裝該工具

1. sudo apt-get install libcurl4-openssl-dev   (官網 Note: If you build libcurl with an SSL package dependency, then it is recommended to build with OpenSSL since EasyCwmp was mainly tested with libcurl using OpenSSL.)

提示:最后出現ldconfig deferred processing now taking place: 編寫測試程序若出現找不到curl文件,最好重啟生效。

2. 測試curl程序

參考:http://blog.csdn.net/u011641885/article/details/46900771

#include <stdio.h>
#include <curl/curl.h>
#include <stdlib.h>
int main(int argc, char *argv[])
{
    CURL *curl;             //定義CURL類型的指針
        CURLcode res;           //定義CURLcode類型的變量,保存返回狀態碼
    if(argc!=2)
    {
        printf("Usage : file <url>;/n");
        exit(1);
    }

    curl = curl_easy_init();        //初始化一個CURL類型的指針
    if(curl!=NULL)
    {
        //設置curl選項. 其中CURLOPT_URL是讓用戶指定url. argv[1]中存放的命令行傳進來的網址
        curl_easy_setopt(curl, CURLOPT_URL, argv[1]);       
        //調用curl_easy_perform 執行我們的設置.並進行相關的操作. 在這里只在屏幕上顯示出來.
        res = curl_easy_perform(curl);
        //清除curl操作.
        curl_easy_cleanup(curl);
    }
    return 0;
}

 

3. json安裝

0.依賴libtool
apt-get install libtool


1.get source
git clone git://github.com/json-c/json-c.git /opt/git/json-c
cd /opt/git/json-c/

2.Generate configuration files:
必須保證libtool工具已經安裝好
./autogen.sh

3. Configure:
./configure

4.build & install
make
make install
ln -sf /usr/local/include/json-c /usr/include/json

4. libubox安裝

0. 依賴工具包cmake
apt-get install cmake

1. 獲取源碼
git clone git://nbd.name/luci2/libubox.git /opt/git/libubox
cd /opt/git/libubox/

2. 配置
cmake CMakeLists.txt -DBUILD_LUA=OFF

遇到提示:package 'json' not found
只要json路徑默認安裝在/usr/local/include
可以不用擔心該提示

3. 編譯安裝
make
遇到錯誤:
blobmsg_json.c:78:2 error: implicit declaration of function 'is_error'
jshn.c:162:2: error: implicit declaration of function 'is_error'
解決辦法:
對應的文件里加入下面定義
#define is_error(ptr) (ptr == NULL)

make install
ln -sf /usr/local/lib/libubox.so /usr/lib/libubox.so
mkdir -p /usr/share/libubox
ln -sf /usr/local/share/libubox/jshn.sh /usr/share/libubox/jshn.sh

 

5. uci安裝

1. 獲取源碼
git clone git://nbd.name/uci.git /opt/git/uci
cd /opt/git/uci/

2. 配置
cmake CMakeLists.txt -DBUILD_LUA=OFF

3. 編譯安裝
make

class="western"
sudo make install
sudo ln -sf /usr/local/bin/uci /sbin/uci
sudo ln -sf /usr/local/lib/libuci.so /usr/lib/libuci.so

6. ubus安裝

1. 獲取源碼
git clone git://nbd.name/luci2/ubus.git /opt/git/ubus
cd /opt/git/ubus/

2. 配置
cmake CMakeLists.txt -DBUILD_LUA=OFF
提示: package 'systemd' not found
可以不用擔心該提示


3. 編譯安裝
make

sudo make install
sudo ln -sf /usr/local/sbin/ubusd /usr/sbin/ubusd
sudo ln -sf /usr/local/lib/libubus.so /usr/lib/libubus.so

 

7. microxml安裝

1. 獲取源碼
git clone https://github.com/pivasoftware/microxml.git /opt/git/microxml
cd /opt/git/microxml/

2. 配置
autoconf -i
./configure --prefix=/usr --enable-threads --enable-shared --enable-static

3. 編譯安裝
make
sudo make install
sudo ln -sf /usr/lib/libmicroxml.so.1.0 /lib/libmicroxml.so
sudo ln -sf /usr/lib/libmicroxml.so.1.0 /lib/libmicroxml.so.1

 

8.easycwmp安裝

1. 獲取源碼
cd /opt/dev/
wget http://easycwmp.org/download/easycwmp-{x}.{y}.{z}.tar.gz
tar -xzvf easycwmp-{x}.{y}.{z}.tar.gz
mv easycwmp-{x}.{y}.{z} easycwmp
cd /opt/dev/easycwmp/

2. 配置
autoconf -i
./configure --enable-debug --enable-devel --enable-jsonc=1

3. 編譯安裝
make

4. 准備配置開發環境
4.1 創建腳本存放目錄
mkdir -p /usr/share/easycwmp/functions
mkdir -p /etc/easycwmp

4.2 創建easycwmp腳本運行的符號鏈接

ln -sf /opt/dev/easycwmp/ext/openwrt/scripts/easycwmp.sh /usr/sbin/easycwmp
ln -sf /opt/dev/easycwmp/ext/openwrt/scripts/defaults /usr/share/easycwmp/defaults
ln -sf /opt/dev/easycwmp/ext/openwrt/scripts/functions/common /usr/share/easycwmp/functions/common
ln -sf /opt/dev/easycwmp/ext/openwrt/scripts/functions/device_info /usr/share/easycwmp/functions/device_info
ln -sf /opt/dev/easycwmp/ext/openwrt/scripts/functions/lan_device /usr/share/easycwmp/functions/lan_device
ln -sf /opt/dev/easycwmp/ext/openwrt/scripts/functions/management_server /usr/share/easycwmp/functions/management_server
ln -sf /opt/dev/easycwmp/ext/openwrt/scripts/functions/management_server /usr/share/easycwmp/functions/management_server

4.3 創建easycwmp配置文件的符號鏈接
 mkdir /etc/config
 ln -sf /opt/dev/easycwmp/ext/openwrt/config/easycwmp /etc/config/easycwmp
4.4 創建easycwmpd進程的符號鏈接
 ln -sf /opt/dev/easycwmp/bin/easycwmpd /usr/sbin/easycwmpd

4.5 export 在easycwmp腳本運行的環境變量
export UCI_CONFIG_DIR="/opt/dev/easycwmp/ext/openwrt/config/"
export UBUS_SOCKET="/var/run/ubus.sock"

4.6 使用Openwrt腳本測試是否easycwmp安裝成功?
sudo mkdir -p /lib/{config,functions}
sudo wget http://pastebin.lukaperkov.net/openwrt/20121219_lib_functions.sh -O /lib/functions.sh
sudo wget http://pastebin.lukaperkov.net/openwrt/20121219_lib_config_uci.sh -O /lib/config/uci.sh
sudo wget http://pastebin.lukaperkov.net/openwrt/20121219_lib_functions_network.sh -O /lib/functions/network.sh

bash /usr/sbin/easycwmp get value InternetGatewayDevice.

遇到錯誤:: 未有任何輸出,解決辦法參考下一步遇到的錯誤

4.7 運行easycwmp
export PATH=$PATH:/usr/sbin:/sbin
ln -sf bash /bin/sh
/usr/sbin/ubusd -s /var/run/ubus.sock &
/usr/sbin/easycwmpd -f -b

遇到錯誤:: error while loading shared libraries: libjson-c.so.3: cannot open shared object file: No such file or directory
解決辦法:如果嚴格按照我的步驟,你會出現找不到libjson庫的問題,因為在安裝libjson的時候默認安裝到/usr/local/lib/路徑下面,所以創建軟連接指向這里即可:
ln -sf /usr/local/lib/libjson-c.so.3.0.0 /usr/lib/libjson-c.so.3

二. 使用openacs測試

1. 設置acs url
vi  /etc/config/easycwmp
修改acs url一行為如下
 option url http://ip:8080/openacs/acs

2.打開openacs
http://ip:8080/openacs
在FindCPE下面看到設備型號,輸入序列號即可進行操作

 

 三. 代碼閱讀

初步閱讀代碼,未發現該開源代碼有什么優勢,這也許就是商業和非商業的區別。 而且在官網上,人家也說了:Data Model部分,shell寫的是開源,隨便你們蹂躪,C寫的才是商業機密,性能比你shell吊炸天!!!!要的就是你在shell里面痛苦,再找我要商業版的,^_^,外國犢子夠奸詐了吧!!!!

有空我也寫個商業版的cwmp,而且要比他還牛逼,我要支持多平台的,不僅僅是linux,那就趕緊眾籌我吧,哈哈,讓我有更多的時間來寫一個吊炸天的程序給你們用。

 

參考:http://www.easycwmp.org/index.php/manual

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM