魏宏安,徐藝文,金志濤
(福州大學(xué) 物理與信息工程學(xué)院,福建 福州 350002)
信息技術(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)無(wú)縫連接。嵌入式系統(tǒng)組成的三個(gè)基本要素[1]為:嵌入、專用性和計(jì)算機(jī)。根據(jù)嵌入式系統(tǒng)本身特性優(yōu)化設(shè)計(jì),引入開(kāi)源TCP/IP協(xié)議棧,并根據(jù)需要進(jìn)行裁剪,利用公共網(wǎng)關(guān)接口(CGI)應(yīng)用開(kāi)發(fā),嵌入式Web服務(wù)器可以向任何接入它所在網(wǎng)絡(luò)的合法用戶提供統(tǒng)一的基于瀏覽器方式的操作和控制界面,提供特定交互功能。
基于當(dāng)前大型服務(wù)器使用的信息管理系統(tǒng)架構(gòu)方案(數(shù)據(jù)庫(kù)+Web服務(wù)器+動(dòng)態(tài)網(wǎng)頁(yè)技術(shù)),本文提出一種面向嵌入式、借助CGI網(wǎng)關(guān)接口開(kāi)發(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ù)載減輕,無(wú)須安裝客戶端軟件,統(tǒng)一的Internet瀏覽器方便了用戶的使用和服務(wù)端的應(yīng)用開(kāi)發(fā),并提供了友好人機(jī)界面設(shè)計(jì)。
(3)系統(tǒng)安全保障提高,避免了客戶端與服務(wù)器的數(shù)據(jù)庫(kù)直接相連。
B/S模式組成部分為:表示層:Web瀏覽器,顯示邏輯部分,充當(dāng) Client角色;功能層:Web服務(wù)器,事務(wù)處理邏輯部分;數(shù)據(jù)層:數(shù)據(jù)庫(kù)服務(wù)器,數(shù)據(jù)處理邏輯部分。功能層和數(shù)據(jù)層共同充當(dāng)Server角色。B/S模式架構(gòu)如圖1所示。
圖1 B/S架構(gòu)圖
協(xié)議接口設(shè)計(jì)借助于Microchip公司提供的免費(fèi)協(xié)議?!狹icrochip TCP/IP協(xié)議棧,它是基于TCP/IP的一套應(yīng)用程序,類似于TCP/IP參考模型,Microchip TCP/IP協(xié)議棧將 TCP/IP協(xié)議棧分為多層,如圖 2所示。每層的實(shí)現(xiàn)代碼駐留在一個(gè)獨(dú)立的源文件中,而服務(wù)和應(yīng)用程序編程接口(API)是通過(guò)頭文件或包含文件定義的。與傳統(tǒng)TCP/IP協(xié)議棧實(shí)現(xiàn)方法的不同,MicrochipTCP/IP協(xié)議棧添加了 StackTask和 ARPTask兩個(gè)新模塊。StackTask管理協(xié)議棧以及所有模塊的操作,而ARPTask管理地址解析協(xié)議ARP(Address ResohJtion Protocol)層的服務(wù)。
圖2 Microchip TCP/IP協(xié)議棧與TCP/IP參考模型的對(duì)比
與完整、復(fù)雜的TCP/IP協(xié)議體系相比,在嵌入式Web服務(wù)器中并不需要實(shí)現(xiàn)所有的協(xié)議,而是基于嵌入式要素特點(diǎn)的要求以及嵌入式系統(tǒng)資源限制進(jìn)行適量裁剪。來(lái)自客戶端的數(shù)據(jù)信息通過(guò)RJ-45以太網(wǎng)接口和網(wǎng)絡(luò)接口芯片傳遞給微控制器,微控制器通過(guò)內(nèi)嵌的Microchip TCP/IP協(xié)議棧實(shí)現(xiàn)了地址解析 (ARP)協(xié)議、Internet控制報(bào)文協(xié)議(ICMP)、IP協(xié)議、用戶數(shù)據(jù)報(bào)(UDP)等協(xié)議的解析和封包,應(yīng)用層上負(fù)責(zé)Web頁(yè)面請(qǐng)求和應(yīng)答的HTTP協(xié)議。本文設(shè)計(jì)的協(xié)議棧管理程序基于協(xié)議的層次性,具有模塊化思想。當(dāng)接收到正確的以太網(wǎng)幀后,根據(jù)以太網(wǎng)的數(shù)據(jù)類型將接收的數(shù)據(jù)送至相應(yīng)的模塊進(jìn)行進(jìn)一步處理。
由于傳統(tǒng)的Web服務(wù)器無(wú)法實(shí)現(xiàn)Web數(shù)據(jù)庫(kù)訪問(wèn)功能,CGI技術(shù)充當(dāng)了訪問(wèn)數(shù)據(jù)庫(kù)的重要媒介。CGI是使用應(yīng)用相關(guān)軟件增強(qiáng)Web服務(wù)器的一種標(biāo)準(zhǔn)方法,可以用任何語(yǔ)言書寫。CGI根據(jù)需求更新網(wǎng)頁(yè),是一種公共網(wǎng)關(guān)接口。它通過(guò)客戶提供給Web服務(wù)器的各種信息,由Web服務(wù)器啟動(dòng)指定CGI模塊函數(shù),完成客戶端與服務(wù)器端動(dòng)態(tài)的交互,從而實(shí)現(xiàn)靜態(tài)HTML網(wǎng)頁(yè)無(wú)法實(shí)現(xiàn)的功能(如表單查詢、數(shù)據(jù)庫(kù)查詢等)。通常CGI應(yīng)用程序處于休眠狀態(tài),通過(guò)使用一定的網(wǎng)絡(luò)事件觸發(fā)回調(diào)函數(shù)來(lái)實(shí)現(xiàn),并顯示動(dòng)態(tài)頁(yè)面。例如,Web服務(wù)器收到一個(gè)URL里面包含的網(wǎng)頁(yè)請(qǐng)求時(shí),將執(zhí)行結(jié)果返回給HTML網(wǎng)頁(yè),CGI可實(shí)現(xiàn)處理表格、數(shù)據(jù)庫(kù)查詢和電子郵件等操作。
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通過(guò)兩種調(diào)用方式獲取客戶請(qǐng)求[4]。
(1)通過(guò) URL直接調(diào)用,如 http://192.168.16.108。
(2)通過(guò)交互式Form調(diào)用,通常是用戶輸入信息主頁(yè)后,點(diǎn)擊“確認(rèn)”按鈕后啟動(dòng)CGI程序。提交數(shù)據(jù)有Get和 Post兩種模式:Get通過(guò)環(huán)境變量傳遞給 CGI程序,Post通過(guò)環(huán)境變量和標(biāo)準(zhǔn)輸入傳遞給 CGI程序。本文采取上述兩種方式調(diào)用CGI模塊函數(shù),并通過(guò)交互式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)格式。
通過(guò)使用一定的網(wǎng)絡(luò)事件觸發(fā)機(jī)制 (如客戶機(jī))向服務(wù)器發(fā)送HTTP請(qǐng)求,即調(diào)用CGI請(qǐng)求。CGI請(qǐng)求中的網(wǎng)絡(luò)參數(shù)等信息是以標(biāo)簽指示的。當(dāng)應(yīng)用程序CGI模塊函數(shù)被調(diào)用時(shí),初始化工作區(qū),把客戶端請(qǐng)求從環(huán)境變量和標(biāo)準(zhǔn)輸入中取出,創(chuàng)建局部變量以匹配請(qǐng)求中的標(biāo)簽。如果沒(méi)有從客戶端傳來(lái)參數(shù)信息,則調(diào)用用戶提供的函數(shù)以取得設(shè)備當(dāng)前狀態(tài),顯示給客戶端瀏覽器。此外,用戶可以通過(guò)網(wǎng)頁(yè)操作界面設(shè)置設(shè)備新的工作網(wǎng)絡(luò)參數(shù)并發(fā)給Web服務(wù)器。Web服務(wù)器利用CGI模塊函數(shù)提取網(wǎng)絡(luò)傳送來(lái)的新網(wǎng)絡(luò)參數(shù),并利用應(yīng)用程序設(shè)定設(shè)備新的狀態(tài),同時(shí)回送給客戶端瀏覽器,通過(guò)客戶端瀏覽器和Web服務(wù)器交互對(duì)設(shè)備進(jìn)行控制。作為嵌入式應(yīng)用開(kāi)發(fā),面對(duì)對(duì)象環(huán)境要求,嵌入到對(duì)象體系中,按對(duì)象的要求對(duì)其軟件和硬件進(jìn)行裁剪,就像標(biāo)準(zhǔn)的CGI作為獨(dú)立可執(zhí)行文件完成的功能,本文中的應(yīng)用是作為一個(gè)CGI模塊函數(shù)嵌入到Web服務(wù)器內(nèi)部,統(tǒng)一編譯后整體運(yùn)行,作為用戶Web開(kāi)發(fā)的接口。
CGI函數(shù)和服務(wù)器之間通過(guò)標(biāo)準(zhǔn)輸入(STDIN)和標(biāo)準(zhǔn)輸出(STDOUT)傳遞信息,如圖3所示。服務(wù)器通過(guò)STDOUT向CGI函數(shù)傳遞需求信息,CGI函數(shù)讀取環(huán)境變量和STDIN,根據(jù)流程將滿足條件的信息輸出給STDOUT。即對(duì)于Web服務(wù)器而言,STDOUT將信息流送至CGI函數(shù)的 STDIN,CGI函數(shù)的 STDOUT信息流將送至服務(wù)器的STDIN,從而形成一個(gè)環(huán)路。
圖3 CGI腳本和Web服務(wù)器之間的輸入輸出流程圖
實(shí)現(xiàn)動(dòng)態(tài)Web頁(yè)面的準(zhǔn)備工作是利用HTML語(yǔ)言編寫Web頁(yè)及內(nèi)建表單,依據(jù)Web網(wǎng)頁(yè)提交的信息項(xiàng)目,編寫對(duì)應(yīng)的CGI模塊程序。
HTML表單是一種把一組URL(如主機(jī)上的一個(gè)文件名)下的控件組成集合的方法,同時(shí)每個(gè)控件保持自己獨(dú)立的標(biāo)識(shí)。該表單仿效可填寫的紙質(zhì)表單,帶有文本區(qū)域和選擇框等。當(dāng)用戶填完表單,即通過(guò)網(wǎng)頁(yè)形式設(shè)置設(shè)備的網(wǎng)絡(luò)參數(shù)后,用戶點(diǎn)擊保存按鈕,把它提交給服務(wù)器。在此過(guò)程中,服務(wù)器接收瀏覽器提取的表單信息,決定返回哪一個(gè)頁(yè)面[5]。
利用標(biāo)記將輸入域組合起來(lái),說(shuō)明表單的名稱、數(shù)據(jù)傳達(dá)的目的地點(diǎn)以及傳送方法等。
采用POST方式進(jìn)行數(shù)據(jù)提交。
客戶端利用IE瀏覽器登錄到服務(wù)器發(fā)出服務(wù)器請(qǐng)求,此處的服務(wù)器就是VOIP系統(tǒng)通話終端設(shè)備。服務(wù)器響應(yīng)用戶請(qǐ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è)置主頁(yè)面,以達(dá)到通過(guò)網(wǎng)絡(luò)遠(yuǎn)程控制嵌入式設(shè)備的目的,如圖5所示。
圖4 身份驗(yàn)證登錄界面
圖5 設(shè)置主頁(yè)面
點(diǎn)擊左欄的網(wǎng)絡(luò)應(yīng)用配置,進(jìn)入到網(wǎng)絡(luò)應(yīng)用配置頁(yè)面,HTML表單語(yǔ)言為:
注冊(cè)服務(wù)器IP地址以標(biāo)簽(config_regserverip)指示,點(diǎn)擊保存按鈕后,服務(wù)器進(jìn)行相應(yīng)處理,此時(shí),提取文本框中用戶的輸入信息“192.168.16.104.”替換標(biāo)簽,即利用表單域中的值進(jìn)行替換,以達(dá)到用戶遠(yuǎn)程對(duì)設(shè)備參數(shù)的設(shè)置功能。所以變成了。
然后利用自定義HTTPPrint_config_regserverip()函數(shù)直接定向到TCP連接,將用戶設(shè)置參數(shù)信息顯示在HTML表單頁(yè)面里。
最終配置頁(yè)面如圖6所示,完成遠(yuǎn)程配置任務(wù)。
圖6 配置頁(yè)面
終端參數(shù)控制只是B/S模式嵌入式Web遠(yuǎn)程控制系統(tǒng)的一個(gè)簡(jiǎn)單應(yīng)用,借助于CGI技術(shù)實(shí)現(xiàn)了Web服務(wù)器和客戶端之間的動(dòng)態(tài)交互,使得用戶能在網(wǎng)絡(luò)環(huán)境的多種平臺(tái)上充分利用統(tǒng)一的客戶工具——瀏覽器,從而為網(wǎng)絡(luò)化遠(yuǎn)程操作提供了可靠保障。
本文設(shè)計(jì)的嵌入式Web服務(wù)器利用以太網(wǎng)作為通信介質(zhì),具有最大的普及范圍;采用標(biāo)準(zhǔn)公開(kāi)化的HTTP通信協(xié)議,獨(dú)立于系統(tǒng)平臺(tái),在客戶端使用任意與Internet互連的標(biāo)準(zhǔn)PC(標(biāo)準(zhǔn)瀏覽器)可以實(shí)現(xiàn)隨時(shí)隨地訪問(wèn)。所使用的Web架構(gòu)獨(dú)立于系統(tǒng)平臺(tái),可以移植到任何嵌入式設(shè)備中,使得該Web服務(wù)器具有通用性。經(jīng)實(shí)際測(cè)試證明,該Web服務(wù)器性能穩(wěn)定可靠,可應(yīng)用在實(shí)時(shí)監(jiān)控、網(wǎng)絡(luò)電話等產(chǎn)品中。
[1]田澤.嵌入式系統(tǒng)開(kāi)發(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)頁(yè)交互[J].交通與計(jì)算機(jī),2000,18(1):22-23.
[5]JEREMY B.嵌入式系統(tǒng)Web服務(wù)器—TCP/IP Lean[M].陳向群等譯.北京:機(jī)械工業(yè)出版社,2003.