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

          新聞中心

          EEPW首頁(yè) > 手機(jī)與無線通信 > 設(shè)計(jì)應(yīng)用 > 基于DWR框架和反向AJAX的Web監(jiān)控系統(tǒng)開發(fā)

          基于DWR框架和反向AJAX的Web監(jiān)控系統(tǒng)開發(fā)

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

          采用和反向,結(jié)合Java多線程技術(shù)和Siemens Simatic S7-400 PLC TCP/IP通訊模塊CP243-1 IT,了新的,并應(yīng)用在供熱公司供熱管路中。其替代了原有的C/S模式的工業(yè)控制機(jī),達(dá)到了用戶的功能需求。

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

            采用了作為的客戶端,極大方便了監(jiān)控系統(tǒng)的操作管理人員,減輕了監(jiān)控系統(tǒng)的維護(hù)成本。如何解決傳統(tǒng)監(jiān)控系統(tǒng)的數(shù)據(jù)讀取請(qǐng)求/響應(yīng)模式的缺點(diǎn),以及監(jiān)測(cè)數(shù)據(jù)顯示頁(yè)面刷新的難題[1],一直是Web監(jiān)控系統(tǒng)人員不懈努力的難題。

            在實(shí)現(xiàn)Web監(jiān)控系統(tǒng)的技術(shù)多種多樣,各有千秋,技術(shù)成為首選之一,不論服務(wù)器端采用JavaEE還是MS.NET平臺(tái)。雖然解決了整個(gè)監(jiān)控畫面的局部刷新問題,但AJAX依然采用HTTP請(qǐng)求/響應(yīng)模式讀取服務(wù)器端取得的Web監(jiān)控?cái)?shù)據(jù)[2]。AJAX[3]最新版本推出了反向AJAX技術(shù),使數(shù)據(jù)從服務(wù)器推送到Web客戶端成為可能,滿足了監(jiān)控系統(tǒng)實(shí)時(shí)性要求。

            采用和反向AJAX,結(jié)合Java多線程技術(shù)和Siemens Simatic S7-400 PLC TCP/IP通訊模塊CP243-1 IT,了新的Web監(jiān)控系統(tǒng),并在供熱公司供熱管路監(jiān)控系統(tǒng)中實(shí)際運(yùn)用。替換了原有的C/S模式的工業(yè)控制機(jī),達(dá)到了用戶的功能需求。

            1 DWR技術(shù)

            1.1 DWR框架

            DWR(Direct Web Remoting)是一個(gè)Web遠(yuǎn)程調(diào)用AJAX擴(kuò)展框架,通過DWR客戶端的JavaScript可以直接調(diào)用Web服務(wù)器上的JavaBean類的方法,解決了原有AJAX應(yīng)用必需請(qǐng)求HTTP控制組件(如Servlet,Struts的Action等)才能調(diào)用服務(wù)器端業(yè)務(wù)類的方法,從而簡(jiǎn)化了AJAX應(yīng)用的開發(fā)。使用DWR可以不需要編寫復(fù)雜的控制層組件。

            1.2 DWR反向AJAX技術(shù)

            正常情況下,DWR調(diào)用服務(wù)器端的JavaBean對(duì)象方法使用正向請(qǐng)求/響應(yīng)模式,也稱為拉模式(Pull Model),由客戶端JavaScript調(diào)用JavaBean方法,返回結(jié)果通過回調(diào)方法更新頁(yè)面上的HTML元素,實(shí)現(xiàn)監(jiān)控?cái)?shù)據(jù)的顯示。這種正向模式符合一般的管理系統(tǒng)應(yīng)用,但對(duì)監(jiān)控系統(tǒng)實(shí)時(shí)性要求較高的應(yīng)用卻力不從心。而反向模式即推模式(Push Model),是適應(yīng)監(jiān)控系統(tǒng)的最佳方式,由服務(wù)器組件將取得的監(jiān)控?cái)?shù)據(jù)推送到Web客戶端,不需要客戶端主動(dòng)請(qǐng)求,而是被動(dòng)接收。因而無需進(jìn)行Web層進(jìn)行頁(yè)面刷新,即可實(shí)現(xiàn)數(shù)據(jù)更新顯示。

            最新版本的DWR 2.X增加了反向(Reverse AJAX)功能,通過反向AJAX功能,服務(wù)器端的JavaBean對(duì)象可以將取得的數(shù)據(jù)直接推送到指定的客戶端頁(yè)面,寫到指定的HTML元素內(nèi),這個(gè)過程不需要客戶端進(jìn)行任何的請(qǐng)求操作。

            2 監(jiān)控系統(tǒng)設(shè)計(jì)與實(shí)現(xiàn)

            2.1 總體結(jié)構(gòu)

            整個(gè)監(jiān)控系統(tǒng)采用下位監(jiān)控子系統(tǒng)、上位Web服務(wù)器和客戶端三層結(jié)構(gòu),如圖1所示。

            


            下位監(jiān)控子系統(tǒng)采用Siemens Simatic S7-400 PLC,連接溫度、壓力及流量傳感器,并配置TCP/IP通信控制單元(CP343)。上位Web服務(wù)器采用開源Tomcat6.0.20,它針對(duì)新的JDK6進(jìn)行了性能的優(yōu)化,極大提高了響應(yīng)速度,滿足監(jiān)控實(shí)時(shí)性需求,在Tomcat6 Web中配置DWR Servlet,負(fù)責(zé)與客戶端Javascript進(jìn)行通信,服務(wù)器端使用JavaBean多線程技術(shù),通過Socket和TCP/IP協(xié)議與PLC通信,讀取PLC監(jiān)控?cái)?shù)據(jù),使用DWR反向AJAX技術(shù)將監(jiān)控?cái)?shù)據(jù)推向客戶端的HTML元素進(jìn)行顯示??蛻舳耸褂肐E瀏覽器被動(dòng)接收服務(wù)器推送的數(shù)據(jù),實(shí)時(shí)更新監(jiān)測(cè)數(shù)據(jù)。

            2.2 服務(wù)器端DWR配置

            為使用DWR,需要在/WEB-INF/web.xml中配置DWR Servlet,并設(shè)定請(qǐng)求URL地址,同時(shí)通過設(shè)置參數(shù)activeReverseAjaxEnabled為true來啟用反向AJAX。配置代碼如下:

            

            2.3 監(jiān)控業(yè)務(wù)單元JavaBean編程

            (1)服務(wù)器端JavaBean

            以多線程方式,每個(gè)監(jiān)測(cè)點(diǎn)為獨(dú)立的線程,使用TCP/IP和Socket讀取Siemens Simatic S7 PLC的監(jiān)測(cè)數(shù)據(jù),并使用DWR Reverse AJAX和DOM直接寫入到客戶端的HTML中。其中一個(gè)監(jiān)測(cè)點(diǎn)線程示意代碼如下:

            

            關(guān)鍵是使用DWR反向AJAX的Util對(duì)象的setValue方法,將監(jiān)測(cè)數(shù)據(jù)寫到DIV元素id為siteNo值的單元中。


          上一頁(yè) 1 2 下一頁(yè)

          評(píng)論


          相關(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); })();