<meter id="pryje"><nav id="pryje"><delect id="pryje"></delect></nav></meter>
          <label id="pryje"></label>

          新聞中心

          EEPW首頁 > 嵌入式系統(tǒng) > 設(shè)計應(yīng)用 > 一種實用的嵌入式Web服務(wù)器設(shè)計

          一種實用的嵌入式Web服務(wù)器設(shè)計

          作者: 時間:2012-05-08 來源:網(wǎng)絡(luò) 收藏

          對于EWS中動態(tài)頁面的生成則要經(jīng)過動態(tài)數(shù)據(jù)解析以及解析數(shù)據(jù)的模板頁面回填這兩個過程。在通常的交互中,大量動態(tài)數(shù)據(jù)是通過表單的形式體現(xiàn)在html頁面之中的。而一般上送的表單數(shù)據(jù)(文件上傳除外)在GET和POST兩種方法下,除了在HTTP請求報文中小現(xiàn)位置的不同外(GET方法下位于請求行,POST方法下位于實體主體部分),其組織形式并無差別,如下所示:
          e_1-v 1&e 2=v 2…&e N=v N
          其中e_N代表表單數(shù)據(jù)中的元素名,v_N代表該元素的取值。
          因此,當(dāng)連接管理模塊從請求報文中提取出表單數(shù)據(jù)后,即可對這兩種方法下的提交數(shù)據(jù)采用相同的解析方法。CGIC采用以下方法來實現(xiàn)其解析過程。
          首先,通過對表單數(shù)據(jù)字符串的節(jié)點分析,用一個單向鏈表來對表單數(shù)據(jù)中的每個元素進(jìn)行維護(hù),在鏈表成員中包括了對元素名及其值的管理,并針對不同的元素類型提供了一系列接口。解析步驟如下:
          ①用于獲取列表框取值的函數(shù)接口cgiFormSelectSingle。
          ②用于獲取文本框取值的函數(shù)接口cgiFormString。
          ③用于獲取復(fù)選框取值的函數(shù)接口cgiFormCheckboxMultiple。
          在需要訪問元素時,只需提供相應(yīng)的元素名,就可方便地使用這些接口對管理鏈表遍歷來獲得相應(yīng)元素的取值。
          當(dāng)CGIC移植時,只需對相應(yīng)元素解析對應(yīng)的函數(shù)進(jìn)行所選系統(tǒng)的修改即可。需要注意的是,對列表和復(fù)選框等非字符取值的獲取,還需按照用戶定義的取值設(shè)置,對相應(yīng)的接口進(jìn)行一定的修改,以適應(yīng)用戶對元素取值范圍的靈活要求。
          所謂解析數(shù)據(jù)的模板頁面回填,是指在動態(tài)頁面中,按照模板中的頁面顯示格式,將頁面中各元素的取值寫入html模板文件中的對應(yīng)位置。html標(biāo)簽代碼如下:
          input name=“devName”type=“text”
          value=“***”size=“15”/>
          它在頁面上表示一元素名為“devName”,取值為“***”的文本框,在數(shù)據(jù)回填到模板頁面時,需要根據(jù)具體的取值如“devl”寫到原“***”的對應(yīng)位置上去。結(jié)果如下:
          input name=“devName”type=“text”
          value=“devl”size=“15”/>
          本文采用以下方法來實現(xiàn)這一處理過程。首先,沒計頁面模板時在每個需要進(jìn)行動態(tài)修改的頁面元素前加上不同的注釋語句,對以上html標(biāo)簽,可加的注釋語句如下(單獨一行):
          !-devName_id->
          在每次解析完表單數(shù)據(jù)并且需要對動態(tài)頁面進(jìn)行重新生成時,就可以通過對模板文件的逐行讀取,來查找相應(yīng)的注釋語句,從而確定數(shù)據(jù)更新的位置。然后再根據(jù)具體的元素取值生成新的html標(biāo)簽字符串,用來對注釋語句后的標(biāo)簽字符串進(jìn)行替換。通過以上過程,即可方便地實現(xiàn)解析數(shù)據(jù)的模板頁面回填,從而生成相應(yīng)的動態(tài)頁面。
          2.4 文件下載和上傳的功能實現(xiàn)
          文件下載和上傳是經(jīng)常具有的一項功能,相對來說文件下載較為簡單,只需將下載時訪問的URL定位于目標(biāo)文件,然后再由將該文件的內(nèi)容直接上送給瀏覽器。而文件上傳功能的實現(xiàn)則相對復(fù)雜,下面對其過程進(jìn)行詳細(xì)的說明。
          首先,要實現(xiàn)文件的上傳,在其頁面設(shè)計時必須采用POST方法來對表單數(shù)據(jù)進(jìn)行提交,并且需要在頁面中將其編碼方式修改為“multipa rt/form-data”,否則將無法在瀏覽器端進(jìn)行文件上傳。然后,通過html表單中的文件元素來進(jìn)行上傳文件的選擇。
          通過以上設(shè)置,上傳給的http報文數(shù)據(jù)將以multipart的編碼形式出現(xiàn)。其特點是,在每個表單元素項的前后均加有一行分界字符串。以文件元素為例,其格式如下:
          --------------------------------7db01d60ffc
          Content-Disposition:form-data;name=“file”; filename=“1.TXT”Content-Type:text/plain
          This is a txt file.
          --------------------------------7db01d60ffc
          其中,“----------------------------7db01d60ffc”為分界字符串。CGlC也提供了對該格式的解析支持。它首先提取出分界字符串,然后再通過cgiParsePostMultltpartInput函數(shù)的操作來實現(xiàn)報文中各表單元素數(shù)據(jù)以及文件數(shù)據(jù)的解析。提取出文件數(shù)據(jù)后,即可將文件內(nèi)容按指定的路徑保存在相應(yīng)的Flash存儲區(qū)中。

          3 性能測試
          通過以上各環(huán)節(jié),即可實現(xiàn)一個相對完整的EWS。綜合以上各個模塊。
          在主頻600 MHz的TMS320DM642處理器上對該EWS從收到請求建立連接到響應(yīng)結(jié)束斷開連接的時間進(jìn)行測試,EWS性能測試如表1所列。

          本文引用地址:http://www.ex-cimer.com/article/149122.htm

          f.jpg


          其中,由于采用了框架結(jié)構(gòu)進(jìn)行設(shè)計,在訪問索引主頁時,涉及的訪問請求次數(shù)較多,所以其測試時間相比其他單次請求來說要較長一些。總體來看,該EWS具有比較快速的服務(wù)響應(yīng)時間,能夠滿足具體應(yīng)用環(huán)境的要求。

          結(jié)語
          本文在BOA和CGIC的基礎(chǔ)上,通過對其代碼的修改以及HTTP協(xié)議報文的分析,將原本運(yùn)行于Linux平臺上獨立的兩個程序進(jìn)行有機(jī)的結(jié)合,成功地將其整合為DSP/BIOS中的一個任務(wù),并提出了一種適合一般系統(tǒng)使用的訪問權(quán)限及對頁面的管理及動態(tài)生成機(jī)制。同時,完成了文件的上傳與下載功能,成功實現(xiàn)了一個相對完整的EWS。

          linux操作系統(tǒng)文章專題:linux操作系統(tǒng)詳解(linux不再難懂)

          上一頁 1 2 3 4 下一頁

          評論


          相關(guān)推薦

          技術(shù)專區(qū)

          關(guān)閉
          看屁屁www成人影院,亚洲人妻成人图片,亚洲精品成人午夜在线,日韩在线 欧美成人 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();