摘 要: 介紹了一種嵌入式Web服務(wù)器應(yīng)用系統(tǒng),。該系統(tǒng)借鑒傳統(tǒng)服務(wù)器系統(tǒng)架構(gòu),基于B/S結(jié)構(gòu)模式設(shè)計,,移植嵌入式TCP/IP協(xié)議棧,,利用CGI技術(shù)以實(shí)現(xiàn)客戶端和服務(wù)器端的動態(tài)數(shù)據(jù)交互。通過本研究可方便實(shí)現(xiàn)系統(tǒng)管理,、遠(yuǎn)程終端參數(shù)設(shè)置等實(shí)際應(yīng)用,。
關(guān)鍵詞: 嵌入式系統(tǒng);Web服務(wù)器,;B/S結(jié)構(gòu)模式,; TCP/IP協(xié)議棧;CGI
信息技術(shù),、網(wǎng)絡(luò)技術(shù)以及嵌入式技術(shù)的飛速發(fā)展和融合,,在嵌入式系統(tǒng)中內(nèi)嵌TCP/IP協(xié)議,將Web服務(wù)器技術(shù)引入到嵌入式系統(tǒng)中,,可使其系統(tǒng)與現(xiàn)今最大的網(wǎng)絡(luò)Internet實(shí)現(xiàn)無縫連接,。嵌入式系統(tǒng)組成的三個基本要素[1]為:嵌入、專用性和計算機(jī),。根據(jù)嵌入式系統(tǒng)本身特性優(yōu)化設(shè)計,,引入開源TCP/IP協(xié)議棧,并根據(jù)需要進(jìn)行裁剪,,利用公共網(wǎng)關(guān)接口(CGI)應(yīng)用開發(fā),,嵌入式Web服務(wù)器可以向任何接入它所在網(wǎng)絡(luò)的合法用戶提供統(tǒng)一的基于瀏覽器方式的操作和控制界面,提供特定交互功能,。
1 嵌入式Web服務(wù)器的系統(tǒng)結(jié)構(gòu)
基于當(dāng)前大型服務(wù)器使用的信息管理系統(tǒng)架構(gòu)方案(數(shù)據(jù)庫+Web服務(wù)器+動態(tài)網(wǎng)頁技術(shù)),,本文提出一種面向嵌入式、借助CGI網(wǎng)關(guān)接口開發(fā)的B/S結(jié)構(gòu)模式Web服務(wù)器信息交互系統(tǒng),,與傳統(tǒng)的兩層C/S模式相比,,其有如下優(yōu)點(diǎn):
(1)系統(tǒng)架構(gòu)維護(hù)方便,可根據(jù)需要更新客戶端程序,,不用像傳統(tǒng)的兩層C/S模式那樣,,必須更新所有客戶端程序,使其保持一致,,系統(tǒng)才可以運(yùn)行管理,。
(2)客戶機(jī)負(fù)載減輕,,無須安裝客戶端軟件,統(tǒng)一的Internet瀏覽器方便了用戶的使用和服務(wù)端的應(yīng)用開發(fā),,并提供了友好人機(jī)界面設(shè)計,。
(3)系統(tǒng)安全保障提高,避免了客戶端與服務(wù)器的數(shù)據(jù)庫直接相連,。
B/S模式組成部分為:表示層:Web瀏覽器,,顯示邏輯部分,充當(dāng)Client角色,;功能層:Web服務(wù)器,,事務(wù)處理邏輯部分;數(shù)據(jù)層:數(shù)據(jù)庫服務(wù)器,,數(shù)據(jù)處理邏輯部分,。功能層和數(shù)據(jù)層共同充當(dāng)Server角色。B/S模式架構(gòu)如圖1所示,。
2 Microchip TCP/IP協(xié)議棧[2]
協(xié)議接口設(shè)計借助于Microchip公司提供的免費(fèi)協(xié)議棧——Microchip TCP/IP協(xié)議棧,,它是基于TCP/IP的一套應(yīng)用程序,,類似于TCP/IP參考模型,,Microchip TCP/IP協(xié)議棧將TCP/IP協(xié)議棧分為多層,如圖2所示,。每層的實(shí)現(xiàn)代碼駐留在一個獨(dú)立的源文件中,,而服務(wù)和應(yīng)用程序編程接口(API)是通過頭文件或包含文件定義的。與傳統(tǒng)TCP/IP協(xié)議棧實(shí)現(xiàn)方法的不同,,Microchip TCP/IP協(xié)議棧添加了StackTask和ARPTask兩個新模塊,。StackTask管理協(xié)議棧以及所有模塊的操作,而ARPTask管理地址解析協(xié)議ARP(Address ResohJtion Protocol)層的服務(wù),。
與完整,、復(fù)雜的TCP/IP協(xié)議體系相比,在嵌入式Web服務(wù)器中并不需要實(shí)現(xiàn)所有的協(xié)議,,而是基于嵌入式要素特點(diǎn)的要求以及嵌入式系統(tǒng)資源限制進(jìn)行適量裁剪,。來自客戶端的數(shù)據(jù)信息通過RJ-45以太網(wǎng)接口和網(wǎng)絡(luò)接口芯片傳遞給微控制器,微控制器通過內(nèi)嵌的Microchip TCP/IP協(xié)議棧實(shí)現(xiàn)了地址解析(ARP)協(xié)議,、Internet控制報文協(xié)議(ICMP),、IP協(xié)議、用戶數(shù)據(jù)報(UDP)等協(xié)議的解析和封包,,應(yīng)用層上負(fù)責(zé)Web頁面請求和應(yīng)答的HTTP協(xié)議,。本文設(shè)計的協(xié)議棧管理程序基于協(xié)議的層次性,具有模塊化思想,。當(dāng)接收到正確的以太網(wǎng)幀后,,根據(jù)以太網(wǎng)的數(shù)據(jù)類型將接收的數(shù)據(jù)送至相應(yīng)的模塊進(jìn)行進(jìn)一步處理,。
3 CGI技術(shù)
由于傳統(tǒng)的Web服務(wù)器無法實(shí)現(xiàn)Web數(shù)據(jù)庫訪問功能,CGI技術(shù)充當(dāng)了訪問數(shù)據(jù)庫的重要媒介,。CGI是使用應(yīng)用相關(guān)軟件增強(qiáng)Web服務(wù)器的一種標(biāo)準(zhǔn)方法,,可以用任何語言書寫。CGI根據(jù)需求更新網(wǎng)頁,,是一種公共網(wǎng)關(guān)接口,。它通過客戶提供給Web服務(wù)器的各種信息,由Web服務(wù)器啟動指定CGI模塊函數(shù),,完成客戶端與服務(wù)器端動態(tài)的交互,,從而實(shí)現(xiàn)靜態(tài)HTML網(wǎng)頁無法實(shí)現(xiàn)的功能(如表單查詢、數(shù)據(jù)庫查詢等),。通常CGI應(yīng)用程序處于休眠狀態(tài),,通過使用一定的網(wǎng)絡(luò)事件觸發(fā)回調(diào)函數(shù)來實(shí)現(xiàn),并顯示動態(tài)頁面,。例如,,Web服務(wù)器收到一個URL里面包含的網(wǎng)頁請求時,將執(zhí)行結(jié)果返回給HTML網(wǎng)頁,,CGI可實(shí)現(xiàn)處理表格,、數(shù)據(jù)庫查詢和電子郵件等操作。
3.1 CGI接口規(guī)范數(shù)據(jù)通信方式
CGI定義的接口規(guī)范包括[3]環(huán)境變量,、標(biāo)準(zhǔn)輸入和標(biāo)準(zhǔn)輸出,。
3.1.1 環(huán)境變量
環(huán)境變量是Web服務(wù)器與CGI程序進(jìn)行數(shù)據(jù)傳遞的途徑,其定義了CGI程序運(yùn)行的環(huán)境,??蛻舳撕头?wù)器端都將有關(guān)數(shù)據(jù)信息轉(zhuǎn)換成各種變量,CGI模塊函數(shù)從環(huán)境變量中提取服務(wù)器或是瀏覽器提供的參數(shù)信息(網(wǎng)絡(luò)設(shè)備參數(shù)),,以此獲取客戶端的信息,。
3.1.2 標(biāo)準(zhǔn)輸入
標(biāo)準(zhǔn)輸入(STDIN)指CGI函數(shù)獲取Web服務(wù)器信息的一種規(guī)范,即使用HTML表單向Web服務(wù)器發(fā)送信息,,通常CGI通過兩種調(diào)用方式獲取客戶請求[4],。
(1)通過URL直接調(diào)用,如http://192.168.16.108,。
(2)通過交互式Form調(diào)用,,通常是用戶輸入信息主頁后,點(diǎn)擊“確認(rèn)”按鈕后啟動CGI程序,。提交數(shù)據(jù)有Get和 Post兩種模式:Get通過環(huán)境變量傳遞給CGI程序,,Post通過環(huán)境變量和標(biāo)準(zhǔn)輸入傳遞給CGI程序。本文采取上述兩種方式調(diào)用CGI模塊函數(shù),,并通過交互式Form調(diào)用,,采用Post提交數(shù)據(jù)方式,,進(jìn)行網(wǎng)絡(luò)參數(shù)設(shè)置。
3.1.3 標(biāo)準(zhǔn)輸出
標(biāo)準(zhǔn)輸出(STDOUT)是CGI輸出的一種方式,,指CGI程序處理結(jié)束后將結(jié)果(如應(yīng)答信息)發(fā)送給Web服務(wù)器的一種方式,。執(zhí)行結(jié)果必須是瀏覽器能夠顯示的HTML標(biāo)準(zhǔn)格式。
3.2 CGI工作原理
通過使用一定的網(wǎng)絡(luò)事件觸發(fā)機(jī)制(如客戶機(jī))向服務(wù)器發(fā)送HTTP請求,,即調(diào)用CGI請求,。CGI請求中的網(wǎng)絡(luò)參數(shù)等信息是以標(biāo)簽指示的。當(dāng)應(yīng)用程序CGI模塊函數(shù)被調(diào)用時,,初始化工作區(qū),,把客戶端請求從環(huán)境變量和標(biāo)準(zhǔn)輸入中取出,創(chuàng)建局部變量以匹配請求中的標(biāo)簽,。如果沒有從客戶端傳來參數(shù)信息,,則調(diào)用用戶提供的函數(shù)以取得設(shè)備當(dāng)前狀態(tài),顯示給客戶端瀏覽器,。此外,,用戶可以通過網(wǎng)頁操作界面設(shè)置設(shè)備新的工作網(wǎng)絡(luò)參數(shù)并發(fā)給Web服務(wù)器。Web服務(wù)器利用CGI模塊函數(shù)提取網(wǎng)絡(luò)傳送來的新網(wǎng)絡(luò)參數(shù),,并利用應(yīng)用程序設(shè)定設(shè)備新的狀態(tài),,同時回送給客戶端瀏覽器,通過客戶端瀏覽器和Web服務(wù)器交互對設(shè)備進(jìn)行控制,。作為嵌入式應(yīng)用開發(fā),,面對對象環(huán)境要求,,嵌入到對象體系中,,按對象的要求對其軟件和硬件進(jìn)行裁剪,就像標(biāo)準(zhǔn)的CGI作為獨(dú)立可執(zhí)行文件完成的功能,,本文中的應(yīng)用是作為一個CGI模塊函數(shù)嵌入到Web服務(wù)器內(nèi)部,,統(tǒng)一編譯后整體運(yùn)行,作為用戶Web開發(fā)的接口,。
3.3 CGI工作流程
CGI函數(shù)和服務(wù)器之間通過標(biāo)準(zhǔn)輸入(STDIN)和標(biāo)準(zhǔn)輸出(STDOUT)傳遞信息,,如圖3所示。服務(wù)器通過STDOUT向CGI函數(shù)傳遞需求信息,,CGI函數(shù)讀取環(huán)境變量和STDIN,,根據(jù)流程將滿足條件的信息輸出給STDOUT。即對于Web服務(wù)器而言,,STDOUT將信息流送至CGI函數(shù)的STDIN,,CGI函數(shù)的STDOUT信息流將送至服務(wù)器的STDIN,從而形成一個環(huán)路,。
4 Web服務(wù)器建立及工作過程
4.1 Web服務(wù)器建立
實(shí)現(xiàn)動態(tài)Web頁面的準(zhǔn)備工作是利用HTML語言編寫Web頁及內(nèi)建表單,,依據(jù)Web網(wǎng)頁提交的信息項目,,編寫對應(yīng)的CGI模塊程序。
HTML 表單是一種把一組URL(如主機(jī)上的一個文件名)下的控件組成集合的方法,,同時每個控件保持自己獨(dú)立的標(biāo)識,。該表單仿效可填寫的紙質(zhì)表單,帶有文本區(qū)域和選擇框等,。當(dāng)用戶填完表單,,即通過網(wǎng)頁形式設(shè)置設(shè)備的網(wǎng)絡(luò)參數(shù)后,用戶點(diǎn)擊保存按鈕,,把它提交給服務(wù)器,。在此過程中,服務(wù)器接收瀏覽器提取的表單信息,,決定返回哪一個頁面[5],。
利用<Form></Form>標(biāo)記將輸入域組合起來,說明表單的名稱,、數(shù)據(jù)傳達(dá)的目的地點(diǎn)以及傳送方法等,。
格式:<form method=METHOD action=”URL” name="FORM NAME">
如上所述,本文表單設(shè)計如下
…
<form method="post" action="serverset.htm" name="serverset">
…
采用POST方式進(jìn)行數(shù)據(jù)提交,。
4.2 Web服務(wù)器工作過程
客戶端利用IE瀏覽器登錄到服務(wù)器發(fā)出服務(wù)器請求,,此處的服務(wù)器就是VOIP系統(tǒng)通話終端設(shè)備。服務(wù)器響應(yīng)用戶請求,,并引導(dǎo)到指定的腳本程序,,即CGI模塊函數(shù)。處于安全的考慮,,需要進(jìn)行相應(yīng)的身份驗(yàn)證,,身份驗(yàn)證登錄界面如圖4所示。
身份驗(yàn)證后,,執(zhí)行CGI應(yīng)用程序,,進(jìn)入終端網(wǎng)絡(luò)參數(shù)信息的設(shè)置主頁面,以達(dá)到通過網(wǎng)絡(luò)遠(yuǎn)程控制嵌入式設(shè)備的目的,,如圖5所示,。
點(diǎn)擊左欄的網(wǎng)絡(luò)應(yīng)用配置,進(jìn)入到網(wǎng)絡(luò)應(yīng)用配置頁面,,HTML表單語言為:
~inc:header.inc~
<div id="content">
<h1>網(wǎng)絡(luò)應(yīng)用配置 </h1>
<form method="post" action="serverset.htm" name="serverset">
<fieldset>
注冊服務(wù)器的語言為:
<div><label>IP地址:</label>
<input type="text" name="regip" value=
"~config_regserverip~" /></div>
…
注冊服務(wù)器IP地址以標(biāo)簽(config_regserverip)指示,,點(diǎn)擊保存按鈕后,服務(wù)器進(jìn)行相應(yīng)處理,,此時,,提取文本框中用戶的輸入信息“192.168.16.104.”替換標(biāo)簽,即利用表單域中的值進(jìn)行替換,,以達(dá)到用戶遠(yuǎn)程對設(shè)備參數(shù)的設(shè)置功能,。所以<input type="text" name="regip" value="~config_regserverip~"/></div>變成了<input type="text" name="regip" value="192.168.16.104" /></div>,。
然后利用自定義HTTPPrint_config_regserverip()函數(shù)直接定向到TCP連接,將用戶設(shè)置參數(shù)信息顯示在HTML表單頁面里,。
case 0x00000034:
HTTPPrint_config_regserverip(),;
break;
void HTTPPrint_config_regserverip(void)
{
TCPPutString(sktHTTP,, NetConfig.ServerIP),;
return;
}
最終配置頁面如圖6所示,,完成遠(yuǎn)程配置任務(wù),。
終端參數(shù)控制只是B/S模式嵌入式Web遠(yuǎn)程控制系統(tǒng)的一個簡單應(yīng)用,借助于CGI技術(shù)實(shí)現(xiàn)了Web服務(wù)器和客戶端之間的動態(tài)交互,,使得用戶能在網(wǎng)絡(luò)環(huán)境的多種平臺上充分利用統(tǒng)一的客戶工具——瀏覽器,,從而為網(wǎng)絡(luò)化遠(yuǎn)程操作提供了可靠保障。
本文設(shè)計的嵌入式Web服務(wù)器利用以太網(wǎng)作為通信介質(zhì),,具有最大的普及范圍,;采用標(biāo)準(zhǔn)公開化的HTTP通信協(xié)議,獨(dú)立于系統(tǒng)平臺,,在客戶端使用任意與Internet互連的標(biāo)準(zhǔn)PC(標(biāo)準(zhǔn)瀏覽器)可以實(shí)現(xiàn)隨時隨地訪問,。所使用的Web架構(gòu)獨(dú)立于系統(tǒng)平臺,可以移植到任何嵌入式設(shè)備中,,使得該Web服務(wù)器具有通用性,。經(jīng)實(shí)際測試證明,該Web服務(wù)器性能穩(wěn)定可靠,,可應(yīng)用在實(shí)時監(jiān)控,、網(wǎng)絡(luò)電話等產(chǎn)品中。
參考文獻(xiàn)
[1] 田澤.嵌入式系統(tǒng)開發(fā)與應(yīng)用[M].北京:北京航天航空大學(xué)出版社,,2005.
[2] Microchip Technology Inc. Microchip TCP/IP 協(xié)議棧[EB/OL].http://ww1.microchip.com/downloads/en/AppNotes/00833c.pdf,, 2008-08-21.
[3] 李勇.CGI技術(shù)在嵌入式WEB服務(wù)器中的應(yīng)用和實(shí)現(xiàn)[J].網(wǎng)絡(luò)與通信,2008,,24(30):110-111.
[4] 何克右.用CGI方式進(jìn)行網(wǎng)頁交互[J].交通與計算機(jī),2000,,18(1):22-23.
[5] JEREMY B.嵌入式系統(tǒng)Web服務(wù)器—TCP/IP Lean[M].陳向群等譯.北京:機(jī)械工業(yè)出版社,,2003.