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

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

本文全部筆記和代碼能夠到csdn下載:http://download.csdn.net/detail/eryunyong/9590036linux

一. linux上安裝git

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

(1)       linux系統:Ubuntu 12.04shell

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

libcurl :json

libuciubuntu

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

libuboxcurl

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

相關文章
相關標籤/搜索