在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

基于AJAX框架DWR、CP243-1 IT和Java多線程技術實現Web監控系統的設計

牽手一起夢 ? 來源:微型機與應用 ? 作者:呂海東,高際邦 ? 2021-04-05 11:23 ? 次閱讀

目前Web監控系統已經得到了普遍運用,許多新的監控系統都采用了Web作為監控系統的客戶端,極大方便了監控系統的操作管理人員,減輕了監控系統的維護成本。如何解決傳統Web監控系統的數據讀取請求/響應模式的缺點,以及監測數據顯示頁面刷新的難題,一直是Web監控系統開發人員不懈努力的難題。

在實現Web監控系統的技術多種多樣,各有千秋,AJAX技術成為首選之一,不論服務器端采用JavaEE還是MS.NET平臺。雖然AJAX解決了整個監控畫面的局部刷新問題,但AJAX依然采用HTTP請求/響應模式讀取服務器端取得的Web監控數據。AJAX框架DWR最新版本推出了反向AJAX技術,使數據從服務器推送到Web客戶端成為可能,滿足了監控系統實時性要求。

采用DWR框架和反向AJAX,結合Java多線程技術和Siemens Simatic S7-400 PLC TCP/IP通訊模塊CP243-1 IT,開發了新的Web監控系統,并在供熱公司供熱管路監控系統中實際運用。替換了原有的C/S模式的工業控制機,達到了用戶的功能需求。

1 DWR技術

1.1 DWR框架

DWR(Direct Web Remoting)是一個Web遠程調用AJAX擴展框架,通過DWR客戶端的JavaScript可以直接調用Web服務器上的JavaBean類的方法,解決了原有AJAX應用必需請求HTTP控制組件(如Servlet,Struts的Action等)才能調用服務器端業務類的方法,從而簡化了AJAX應用的開發。使用DWR可以不需要編寫復雜的控制層組件。

1.2 DWR反向AJAX技術

正常情況下,DWR調用服務器端的JavaBean對象方法使用正向請求/響應模式,也稱為拉模式(Pull Model),由客戶端JavaScript調用JavaBean方法,返回結果通過回調方法更新頁面上的HTML元素,實現監控數據的顯示。這種正向模式符合一般的管理系統應用,但對監控系統實時性要求較高的應用卻力不從心。而反向模式即推模式(Push Model),是適應監控系統的最佳方式,由服務器組件將取得的監控數據推送到Web客戶端,不需要客戶端主動請求,而是被動接收。因而無需進行Web層進行頁面刷新,即可實現數據更新顯示。

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

2 監控系統設計與實現

2.1 總體結構

整個監控系統采用下位監控子系統、上位Web服務器和客戶端三層結構,如圖1所示。

基于AJAX框架DWR、CP243-1 IT和Java多線程技術實現Web監控系統的設計

下位監控子系統采用Siemens Simatic S7-400 PLC,連接溫度、壓力及流量傳感器,并配置TCP/IP通信控制單元(CP343)。上位Web服務器采用開源Tomcat6.0.20,它針對新的JDK6進行了性能的優化,極大提高了響應速度,滿足監控實時性需求,在Tomcat6 Web中配置DWR Servlet,負責與客戶端Javascript進行通信,服務器端使用JavaBean多線程技術,通過Socket和TCP/IP協議與PLC通信,讀取PLC監控數據,使用DWR反向AJAX技術將監控數據推向客戶端的HTML元素進行顯示。客戶端使用IE瀏覽器被動接收服務器推送的數據,實時更新監測數據。

2.2 服務器端DWR配置

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

<servlet>

<servlet-name>dwr-invoker</servlet-name>

<servlet-class>org.directwebremoting.servlet.DwrServlet</servlet-class>

<init-param

<param-name>activeReverseAjaxEnabled</param-name>

<param-value>true</param-value>

</init-param>

<init-param>

<param-name>pollAndCometEnabled</param-name>

<param-value>true</param-value>

</init-param>

<load-on-startup>1</load-on-startup>

</servlet>

<servlet-mapping>

<servlet-name>dwr-invoker</servlet-name>

<url-pattern>/dwr/*</url-pattern>

</servlet-mapping>

2.3 監控業務單元JavaBean編程

(1)服務器端JavaBean

以多線程方式,每個監測點為獨立的線程,使用TCP/IP和Socket讀取Siemens Simatic S7 PLC的監測數據,并使用DWR Reverse AJAX和DOM直接寫入到客戶端的HTML中。其中一個監測點線程示意代碼如下:

public void run() throws InterruptedException

{

WebContext wctx=WebContextFactory.get();

String currentPage=wctx.getCurrentPage();

Collection sessions=wctx.getScriptSessionsByPage(currentPage);

//通過TCP/IP讀取PLC指定監測點的數據

double data=PLCRemote.getData(ip,siteNo);

Util utilAll=new Util(sessions);

//將監測數據通過DWR反向AJAX直接寫入客戶HTML頁面<div>元素中

utilAll.setValue(siteNo,String.valueOf(date));

}

關鍵是使用DWR反向AJAX的Util對象的setValue方法,將監測數據寫到DIV元素id為siteNo值的單元中。

(2)配置JavaBean到DWR

使用DWR的配置文件/WEB-INF/dwr.xml,將JavaBean引入到DWR體系中,通過JavaScript就可以直接調用JavaBean的監測方法。

<dwr>

<allow>

<convert match=“com.lushu.control.value.*” converter=“bean”></convert>

<create creator=“new” javascript=“DataChecking”>

<param name=“class” value=“com.lushu.control.business.DataChecking”/>

</create>

</allow>

</dwr>

其中,javascript屬性指定JavaScript中對象的名稱,creator=“new”指定由DWR引擎自動創建JavaBean類的實例。

2.4 客戶端實現

客戶端使用DWR代碼庫,用JavaScript結合HTML,DOM實現監控Web頁面的數據顯示。為節省篇幅,只介紹重點配置和示意代碼。

(1)引入DWR代碼庫

這里使用HTML與JavaScript分離原則,JavaScript代碼放在單獨的JS文件中。

<script type=‘text/javascript’ src=‘/lsweb/dwr/util.js’></script>

<script type=‘text/javascript’ src=‘/lsweb/dwr/interface/DataChecking.js’></script>

<script type=‘text/javascript’ src=‘/lsweb/dwr/engine.js’></script>

<script type=‘text/javascript’ src=‘main.js’></script>

(2)啟用DWR反向AJAX

在main.js中定義所有監控業務的函數。

function checkInit()

{ dwr.engine.setActiveReverseAjax(true); }

window.onload=checkInit;

(3)定義監控數據接收HTML單元

在監控頁面上使用<div id=”測點ID”></div>定義DWR反向AJAX推送數據的顯示位置,由服務器端JavaBean通過DWR AJAX直接讀取。客戶端頁面和JavaScript不需進行任何請求操作。部分測點示意如下:

<tr>

<td>一小區#2</td>

<td><div id=“no01”></div></td>

<td><div id=“no02”></div></td>

<td><div id=“no03”></div></td>

</tr>

(4)JavaScript調用JavaBean方法

啟動服務器端JavaBean監測方法讀取PLC數據,進行數據推送。在監測方法內啟動所有監測點的監測線程,實時監測數據并推送到客戶端。

function startChecking()

{

//通過DWR直接調用服務器端JavaBean的監測數據方法

DataChecking.sendCheckData();

}

結合JavaEE平臺、AJAX、DWR和反向AJAX,實現了一個全新的無需頁面刷新、無需進行HTTP請求的全新Web監控系統,解決了傳統Web的HTTP請求/響應模式無法滿足監控系統實時性要求的難題。尤其是反向AJAX技術實現的推模式,可以將服務器端監測數據直接通過TCP/IP推送到HTML客戶端,并直接寫入到HTML元素中,得以實現與現有Web監控系統傳統模式完全不同的全新系統,實現了無需進行頁面刷新的工作模式。由于只傳輸監控數據,無需傳輸數據格式HTML代碼,系統性能得到了極大改善,滿足了監控系統對實時性的要求。今后無刷新、推模式的Web監控系統必將得到廣泛應用。

責任編輯:gt

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 服務器
    +關注

    關注

    12

    文章

    9160

    瀏覽量

    85416
  • 監控系統
    +關注

    關注

    21

    文章

    3914

    瀏覽量

    174693
  • 線程
    +關注

    關注

    0

    文章

    504

    瀏覽量

    19682
收藏 人收藏

    評論

    相關推薦

    采用DWR框架和反向AJAXWeb監控系統開發

      采用DWR框架和反向AJAX,結合Java多線程技術和Siemens Simatic S7-
    發表于 08-04 10:48 ?1665次閱讀
    采用<b class='flag-5'>DWR</b><b class='flag-5'>框架</b>和反向<b class='flag-5'>AJAX</b>的<b class='flag-5'>Web</b><b class='flag-5'>監控</b><b class='flag-5'>系統</b>開發

    Java多線程的用法

    能力。 什么是進程 是指正在運行的程序的實例。 每個進程都擁有自己的內存空間、代碼、數據和文件等資源,可以獨立運行、調度和管理。在操作系統中,進程是系統資源分配的最小單位,是實現多任務的基礎。
    的頭像 發表于 09-30 17:07 ?951次閱讀

    基于TCP/IP協議和多線程的通信軟件的設計與實現

    】:0引言通信軟件是船舶導航監控系統的重要組成部分,集數據采集、通信、顯示功能于一體,是實現水上智能交通的核心環節[1]。通信軟件的實時性、準確性和效率直接影響船舶導航
    發表于 05-06 09:02

    [轉帖]學JAVA需要掌握的技術及流程

    的最新教學內容及流程,供大家參考。 1.java的基礎知識 不要被新技術迷惑,所謂萬變不離其宗,新技術都是基于java的基礎之上,如果基礎不扎實,對于這些新
    發表于 05-14 13:19

    Java工程師必須掌握的技術有哪些?

    配置以及進行調試3. j2ee 框架只要你是用java來做WEB應用,絕對少不了使用j2ee框架,目前流行的有1)struts2)sprin
    發表于 02-09 16:18

    多線程技術在變電站監控系統中有哪些應用?

    如何去實現嵌入式Internet系統中的網絡互連?多線程技術在變電站監控系統中有哪些應用?
    發表于 05-25 06:51

    java多線程編程實例 (源程序)

    java多線程編程實例 import java.awt.*;import javax.swing.*; public class CompMover extends Object { 
    發表于 10-22 11:48 ?0次下載

    再談多線程技術在變電站監控系統中的應用

    介紹了Win32 中多線程技術的概念及在Delphi 開發環境中實現的方法,給出了在變電站監控系統開發中如何較好地應用
    發表于 05-30 10:17 ?15次下載

    多線程技術在電能質量實時監控系統中的應用

         實時監控系統具有較高的實時性要求,多線程技術因其能同時執行多項任務而能夠較好地滿足這一要求。本文介紹了
    發表于 09-04 09:59 ?9次下載

    基于AJAX技術WEB研究與實現

    本文介紹了AJAX技術及其工作原理以及所涉及的主要技術與當前的應用狀況。討論了大學人事管理系統若采用傳統WEB方法
    發表于 03-01 16:03 ?12次下載

    java多線程設計模式_結城浩

    JAVA多線程設計模式》通過淺顯易懂的文字與實例來介紹JAVA線程相關的設計模式概念,并且通過實際的JAVA程序范例和UML圖示來一一解說
    發表于 01-05 16:15 ?0次下載
    <b class='flag-5'>java</b><b class='flag-5'>多線程</b>設計模式_結城浩

    CP243-1通信處理器使用手冊

    CP 243-1 是一款適用于在 S7-200 自動化系統中運行的通信處理器。它可用于將 S7-200系統連接到工業以太網 (IE, Industrial Ethernet)。使用
    發表于 11-13 12:35 ?9次下載

    java學習——java面試【事務、鎖、多線程】資料整理

    本文檔內容介紹了基于java學習java面試【事務、鎖、多線程】資料整理,供參考
    發表于 03-13 13:53 ?0次下載

    西門子CP243-1以太網向導配置圖解

    CP243-1模塊是S7-200系列產品中唯一一款以太網通信模塊,它既可以作為西門子以太網S7通信中的客戶端,也可作為服務器。那么,如果想通過以 太網通信與PC機中的STEP 7-Micro/WIN軟件通信,實現編程的上載、下載或在線
    發表于 02-09 18:06 ?1.4w次閱讀
    西門子<b class='flag-5'>CP243-1</b>以太網向導配置圖解

    java實現多線程的幾種方式

    了多種實現多線程的方式,本文將詳細介紹以下幾種方式: 1.繼承Thread類 2.實現Runnable接口 3.Callable和Future 4.
    的頭像 發表于 03-14 16:55 ?708次閱讀
    主站蜘蛛池模板: 六月婷婷导航福利在线| 成人av.com| 午夜秒播| 国产在线观看黄色| 天天碰人人| 黄色毛片子| 久久国产精品系列| 中文天堂最新版在线精品| 女人扒开腿让男人桶到爽| 天天干天天操天天做| 午夜寂寞影视| 免费一级毛片| 免费观看成人欧美1314www| 美女被异性狂揉下部羞羞视频 | 一级欧美日韩| 久久网站免费观看| 狠狠操夜夜爽| 亚洲成人在线播放| wwwwww日本| 中文字幕一区二区三区在线不卡 | 色婷婷一区| 夜夜爽夜夜爽| 在线精品国产第一页| 欧美日a| 日日干干| 亚洲一区二区电影| 成年黄网站免费大全毛片| xxx黄色片| 女人色视频| 国产大片免费观看中文字幕| 性欧美video视频另类| www.xxx.国产| 视频在线观看一区| 极品美女写真菠萝蜜视频| 26uuu欧美性色| 人与禽性视频77777| 免费一级毛片不卡在线播放| 羞涩妩媚玉腿呻吟嗯啊销魂迎合| 怡红院影院| 成人aaa| 18女人毛片水真多免费|