欧美性猛交XXXX免费看蜜桃,成人网18免费韩国,亚洲国产成人精品区综合,欧美日韩一区二区三区高清不卡,亚洲综合一区二区精品久久

打開(kāi)APP
userphoto
未登錄

開(kāi)通VIP,暢享免費電子書(shū)等14項超值服

開(kāi)通VIP
為 WebSphere Application Server Community Edit...

引言

Ajax(異步 JavaScript 和 XML)術(shù)語(yǔ)用于表示一組支持創(chuàng )建富 Internet 應用程序 (Rich Internet Application) 的技術(shù)。通過(guò)使用這些技術(shù),可以創(chuàng )建響應能力強且具有與桌面應用程序類(lèi)似的豐富用戶(hù)界面的 Web 應用程序。這些技術(shù)允許在后臺以異步方式檢索數據,而不會(huì )影響所顯示的頁(yè)面,而且可以?xún)H請求數據,而不用請求整個(gè) HTML 頁(yè)面??梢允褂矛F在的瀏覽器提供的 XmlHttpRequest 或等效對象進(jìn)行此異步后臺通信。

IBM WebSphere Application Server Community Edition v2.1.x(以下稱(chēng)為 Community Edition)的安裝包中提供了一些用于開(kāi)發(fā)和承載支持 Ajax 的應用程序的流行框架。在本文中,我們將了解如何配置和使用其中的三個(gè)框架,即:

  • Dojo 工具包
  • Direct Web Remoting (DWR)
  • Tomcat Comet 支持

我們還將開(kāi)發(fā)一個(gè)簡(jiǎn)單的 Web 應用程序,其中使用了這些技術(shù)來(lái)提供得到改善的用戶(hù)體驗。為了遵循本文所述進(jìn)行操作,您需要 WebSphere Application Server Community Edition v2.1.x。


Dojo 工具包

Dojo 是使用 JavaScript 編寫(xiě)的開(kāi)源 DHTML 工具集。Dojo 解決了使用 JavaScript 時(shí)的一些問(wèn)題,包括處理瀏覽器特定的行為。這些行為已經(jīng)通過(guò) Dojo 工具從用戶(hù)層面抽象出來(lái)了。

另外,還提供了一組可配置小部件,可將其用于快速開(kāi)發(fā)獨立于瀏覽器的動(dòng)態(tài)網(wǎng)頁(yè)。Dojo 工具集由一組 JavaScript API 組成,包含在 WebSphere Application Server Community Edition v 2.1 中??梢酝ㄟ^(guò)上下文根 /dojo 訪(fǎng)問(wèn)此工具集。Dojo 還提供了用于進(jìn)行異步 XMLHttpRequest 調用的 API,以在不刷新頁(yè)面的情況下從服務(wù)器獲取數據。


Direct Web Remoting (DWR)

DWR 允許開(kāi)發(fā)人員通過(guò) JavaScript 代理向客戶(hù)端公開(kāi)服務(wù)器端的 Java? 對象。它會(huì )為所有公開(kāi)的 Java? 對象創(chuàng )建代理,以便從客戶(hù)端調用這些對象。相應地,DWR 將在服務(wù)器中調用對應的 Java 方法,并將響應以 JSON (JavaScript Object Notation) 格式返回到調用方腳本。

您可以配置 DWR 在后臺以同步或異步方式呼叫服務(wù)器。因此,可以避免與普通 HTTP 請求-響應模式關(guān)聯(lián)的頁(yè)面刷新。

DWR 還提供了 Reverse Ajax,即用于將信息從服務(wù)器以異步方式發(fā)送到瀏覽器的機制。通過(guò)這樣,服務(wù)器可以采用以下方式定期將響應發(fā)送到客戶(hù)端:

  • 輪詢(xún):客戶(hù)端定期輪詢(xún)服務(wù)器。
  • Comet:當客戶(hù)端發(fā)出請求時(shí),服務(wù)器將保留響應句柄,寫(xiě)入內容保存在此句柄中。在這種情況下,客戶(hù)端不需要進(jìn)行輪詢(xún)。
  • 合并: 多個(gè)響應組合在一起,隨客戶(hù)端作出的下一個(gè)請求的響應一起發(fā)送。

Tomcat Comet 支持

Comet 術(shù)語(yǔ)是 Dojo Foundation 的 Alex Russel 發(fā)明的,用于描述通過(guò) HTTP 協(xié)議進(jìn)行的事件驅動(dòng)的服務(wù)器推送機制。在普通 HTTP 通信中,客戶(hù)端始終通過(guò)打開(kāi)到服務(wù)器的連接并發(fā)送請求來(lái)發(fā)起數據傳輸。服務(wù)器將處理此請求,在相同連接上發(fā)送響應,然后關(guān)閉連接。因此,連接的壽命相對較短。在 Comet 中,服務(wù)器將連接保持開(kāi)放狀態(tài),會(huì )在出現相關(guān)事件時(shí)持續通過(guò)其寫(xiě)入數據。Tomcat p通過(guò) NIO 和 APR 連接器提供了此支持。BIO 連接器并不提供 Comet 支持。


創(chuàng )建 NIO 連接器

缺省情況下,Community Edition 并不提供預安裝的 NIO 連接器。在運行使用 Comet 協(xié)議的應用程序前,我們需要從管理控制臺創(chuàng )建新 NIO 連接器并將其啟動(dòng)。我們將首先刪除在 8080 端口上運行的 BIO 連接器,然后創(chuàng )建在此端口運行的新 NIO 連接器。

請按照以下步驟創(chuàng )建 NIO 連接器:

  1. 啟動(dòng) Community Edition,并在瀏覽器中打開(kāi) https://localhost:8443/console/。
  2. 輸入用戶(hù)名 system,并輸入密碼 manager。點(diǎn)擊 Login,將隨即在管理控制臺中打開(kāi) Welcome 頁(yè)。
  3. 在左側導航窗格中,單擊 Web Server 鏈接,以打開(kāi) Web Server Manager 頁(yè),如圖 1 中所示:

    圖 1. Web Server Manager


  4. 刪除名為 TomcatWebConnector 的連接器。

  5. 在 Add New 部分,單擊 Tomcat NIO Connector 鏈接,將隨即打開(kāi)圖 2 中所示的屏幕。

    圖 2. 添加新的 Tomcat NIO 連接器


  6. uniqueName 字段中填寫(xiě) TomcatNIOConnector 值,并點(diǎn)擊 Save,從而創(chuàng )建并啟動(dòng) NIO 連接器。您的窗口顯示應該與圖 3 類(lèi)似。

    圖 3. 添加到網(wǎng)絡(luò )偵聽(tīng)器的 TomcatNIOConnector



開(kāi)發(fā) Web 應用程序

我們現在已經(jīng)完成了所有準備工作,可以開(kāi)始開(kāi)發(fā) Web 應用程序了。這是一個(gè)股票報價(jià)器應用程序,每 5 秒鐘將使用最新的報價(jià)進(jìn)行一次更新。我們將在 Tomcat 提供的 Comet 實(shí)現上使用 DWR 的 Reverse Ajax 功能。為了顯示報價(jià),我們將使用 Dojo 工具中提供的一個(gè)現成 Dojo 小部件,即 dojox.Grid 小部件。我們還將編寫(xiě)一個(gè) Servlet 來(lái)使用 Tomcat 中的 Comet 支持打印股票信息。

編寫(xiě) Comet Servlet

Apache Tomcat 提供了 org.apache.catalina.CometProcessor 接口,以便編寫(xiě)的所有 Servlet 都能夠使用 Comet 支持。此接口定義了在我們的 Servlet 中實(shí)現的名為 public void event(CometEvent event) 的單個(gè)方法。清單 1 顯示了此 Servlet 的兩個(gè)主要方法:


清單 1:Comet Servlet
            public void init() throws ServletException {            super.init();            Runnable r = new Runnable() {            public void run() {            while (!stop) {            synchronized (openConnections){            List<Stock> stocks = new StockService().getStocks();            for (HttpServletResponse response : openConnections) {            try {            PrintWriter pw = response.getWriter();            for (Stock stock : stocks) {            pw.println(stock.getSymbol() + ":"            + stock.getPrice());            }            pw.flush();            } catch (IOException e) {            e.printStackTrace(System.out);            }            }            }            try {            Thread.sleep(5000);            } catch (InterruptedException e) {            e.printStackTrace(System.out);            }            }            }            };            Thread stockThread = new Thread(r);            stockThread.setDaemon(true);            stockThread.start();            }            public void event(CometEvent event) throws IOException, ServletException {            HttpServletRequest request = event.getHttpServletRequest();            HttpServletResponse response = event.getHttpServletResponse();            if (event.getEventType() == CometEvent.EventType.BEGIN) {            synchronized (openConnections){            openConnections.add(response);            }            } else if (event.getEventType() == CometEvent.EventType.ERROR) {            synchronized (openConnections){            openConnections.remove(response);            }            } else if (event.getEventType() == CometEvent.EventType.END) {            synchronized (openConnections){            openConnections.remove(response);            }            } else if (event.getEventType() == CometEvent.EventType.READ) {            }            }            

init 方法中,我們將實(shí)例化獲取股票報價(jià)的線(xiàn)程,此線(xiàn)程還要將這些報價(jià)寫(xiě)入所有正在偵聽(tīng)的客戶(hù)端,即 openConnections 列表中的所有響應對象。出現四個(gè)事件(BEGIN、ERROR、END、READ)中的任意事件時(shí),都會(huì )觸發(fā) event 方法。我們從作為參數傳遞的 org.apache.catalina.CometEvent 對象中獲得響應。對于 BEGIN 事件,要將響應添加到集合中。對于 ERROREND 事件,我們將從列表中刪除響應。

BEGIN 事件代表著(zhù)該連接處理開(kāi)始,因此我們要將響應添加到響應列表中。ENDERROR 事件代表著(zhù)連接結束或出現了錯誤。有關(guān)這些事件的含義的更多信息,請參見(jiàn) Apache Tomcat 文檔。

配置 DWR

應用程序硬編碼了一組要顯示的股票。股票值由 com.dev.trade.service.StockQuoteGenerator 類(lèi)隨機更新。清單 2 顯示了這個(gè)類(lèi)的源代碼的相關(guān)部分。


清單 2:生成股票價(jià)格的類(lèi)
            package com.dev.trade.service;            import java.util.HashSet;            import java.util.List;            import java.util.Set;            import java.util.Collections;            import com.dev.trade.bo.Stock;            public class StockQuoteGenerator {            private StockService ss = new StockService();            private List<Stock>  stocks = null;            private static StockQuoteGenerator generator = new StockQuoteGenerator();            private Set<QuoteListener>            listeners = Collections.synchronizedSet(new HashSet<QuoteListener> ());            private volatile boolean contextDestroyed = false;            private StockQuoteGenerator() {            Runnable r = new Runnable() {            public void run() {            try {            while (!contextDestroyed) {            update(generateStockQuotes());            Thread.sleep(5000);            }            }catch (Exception e) {            e.printStackTrace(System.out);            }            }            };            Thread t = new Thread(r);            t.setDaemon(true);            t.start();            }            public static StockQuoteGenerator getInstance() {            return generator;            }            public void setContextDestroyed(boolean cd) {            this.contextDestroyed = cd;            }            public void addListener(QuoteListener listener) {            listeners.add(listener);            }            private void update(List<Stock>  stocks) {            for (QuoteListener listener : listeners) {            listener.updateStockQuotes(stocks);            }            }            private List<Stock>  generateStockQuotes() {            stocks = ss.getStocks();            return stocks;            }            }            

在 StockQuoteGenerator 類(lèi)(一個(gè)單態(tài)類(lèi))的構造函數中,我們啟動(dòng)了一個(gè)新線(xiàn)程,并向該線(xiàn)程分配了一個(gè) Runnable 對象。因此,這個(gè)對象的 run 方法將繼續執行,直到將 contextDestroyed 變量設置為 true 為止。此變量?jì)H在應用程序上下文要銷(xiāo)毀時(shí)才會(huì )設置為 true。為此,我們將在 web.xml 中注冊一個(gè)上下文偵聽(tīng)器,即 com.dev.trade.listener.ServletContextListener。

generateStockQuotes 方法調用 StockServicegetStocks 方法來(lái)獲取生成的股票報價(jià)。使用 addListener 方法可添加偵聽(tīng)器。這些偵聽(tīng)器實(shí)現 com.dev.trade.service.QuoteListener 接口以及相應的 updateStockQuotes 方法。

這些偵聽(tīng)器都是 com.dev.trade.service.StockQuoteListenerImpl 的實(shí)例。此類(lèi)在其構造函數中初始化 DWR 提供的 org.directwebremoting.WebContext 類(lèi)的實(shí)例,然后向 StockQuoteGenerator's 偵聽(tīng)器列表注冊自身。清單 3 顯示了此類(lèi)的 updateStockQuotes 方法。


清單 3:向不同客戶(hù)端推送數據的代碼
            public void updateStockQuotes(List<Stock> stocks) {            ScriptBuffer script = new ScriptBuffer();            script.appendScript("updateStocks(").appendData(stocks).appendScript(            ");");            Collection<ScriptSession> sessions = wctx.getAllScriptSessions();            for (ScriptSession session : sessions) {            if(!session.isInvalidated()){            session.addScript(script);            } else {            wctx.getAllScriptSessions().remove(session);            }            }            }            

此方法將 JavaScript 函數調用傳播到所有開(kāi)放客戶(hù)端。將會(huì )調用函數 updateStocks 并傳遞股票值。此 JavaScript 方法實(shí)際更新我們將顯示的 Dojo 網(wǎng)格小部件的模型,然后調用其 update 方法,以讓網(wǎng)格顯示新數據。DWR 為每個(gè)開(kāi)放股票報價(jià)器頁(yè)創(chuàng )建腳本會(huì )話(huà)。

請注意,為了使其工作,應該由執行 DWR 代碼的同一個(gè)線(xiàn)程調用 StockQuoteListenerImpl 類(lèi)的構造函數。為此,我們將需要配置 DWR,以實(shí)例化 StockQuoteListenerImpl 的對象。對于此配置,我們將創(chuàng )建 dwr.xml 文件,并將其放置在應用程序的 WEB-INF 目錄中。清單 4 顯示了此文件。


清單 4:dwr.xml
            <dwr>            <allow>            <create creator="new" javascript="Ticker" scope="application">            <param name="class" value="com.dev.trade.service.StockQuoteListenerImpl"/>            </create>            <create creator="new" javascript="StockService" scope="application">            <param name="class" value="com.dev.trade.service.StockService"/>            </create>            <convert converter="bean" match="com.dev.trade.bo.Stock"/>            </allow>            </dwr>            

請注意,StockQuoteListenerImpl 已經(jīng)通過(guò)創(chuàng )建程序在 dwr.xml 中公開(kāi)。我們將此對象的范圍設置為 application,因為每個(gè)應用程序只需要一個(gè)此對象的實(shí)例。我們向 JavaScript 公開(kāi)的另一個(gè)類(lèi)是 com.dev.trade.service.StockService,此類(lèi)為我們提供了用于獲得股票列表的 getStocks 方法。我們還需要將 DWRServlet 添加到應用程序的 web.xml,以便初始化 DWR,并由其將所配置的上述對象的代理向 JavaScript 公開(kāi)。清單 5 顯示了 web.xml 文件。


清單 5:web.xml
            <?xml version="1.0" encoding="UTF-8"?>            <web-app xmlns="http://java.sun.com/xml/ns/j2ee" version="2.4"            xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"            xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee            http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">            <display-name>brokerage</display-name>            <listener>            <listener-class>            com.dev.trade.listener.DwrContextListener            </listener-class>            </listener>            <servlet>            <display-name>DWR Servlet</display-name>            <servlet-name>dwr-invoker</servlet-name>            <servlet-class>org.directwebremoting.servlet.DwrServlet</servlet-class>            <init-param>            <param-name>debug</param-name>            <param-value>true</param-value>            </init-param>            <init-param>            <param-name>activeReverseAjaxEnabled</param-name>            <param-value>true</param-value>            </init-param>            <init-param>            <param-name>initApplicationScopeCreatorsAtStartup</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>            <welcome-file-list>            <welcome-file>/stocks.html</welcome-file>            </welcome-file-list>            </web-app>            

activeReverseAjaxEnabled 屬性設置為 true,以便 DWR 使用 Comet 來(lái)啟用 Reverse Ajax。如果設置為 false,則 DWR 將使用合并選項。

initApplicationScopeCreatorsAtStartup 用于在啟動(dòng) DWR 時(shí)初始化所有應用程序范圍內的對象。

現在,我們需要在客戶(hù)端導入兩個(gè)腳本文件:DWR 客戶(hù)端引擎和 DWR 為公開(kāi)的對象 com.dev.trade.service.StockService 創(chuàng )建的 JavaScript 代理。清單 6 顯示了此導入對應的代碼。


清單 6:在客戶(hù)端上進(jìn)行訪(fǎng)問(wèn)
            <script type="text/javascript" src="dwr/engine.js"></script>            <script type='text/javascript'            src='/brokerage/dwr/interface/StockService.js'></script>            

我們還需要配置 DWR 客戶(hù)端引擎,以使用活動(dòng) Reverse Ajax,因此我們需要調用 dwr.engine.setActiveReverseAjax(true)。

我們可以調用 StockServicegetStocks 方法,以使用 StockService.getStocks({callback:getModel,async:false}) 對要顯示的 Dojo 網(wǎng)格小部件進(jìn)行初始填充。getModel 參數引用將調用的 JavaScript 方法,此調用的結果將作為方法參數傳遞。

清單 7 所示的方法將返回我們要顯示的 Dojo 網(wǎng)格的模型。


清單 7:Web Remoting
            function getModel(stocks) {            var data = new Array();            for ( var i = 0; i < stocks.length; i++) {            var subData = new Array();            subData[0] = stocks[i].symbol;            subData[1] = stocks[i].companyName            subData[2] = stocks[i].price            subData[3] = stocks[i].eps            data[i] = subData;            }            updatedModel = new dojox.grid.data.Table(null, data);            return updatedModel;            }            

配置 Dojo

Community Edition 隨附了 Dojo JavaScript 庫。其中對一些管理控制臺 Portlet 使用了 Dojo。Dojo 打包為在上下文根 /dojo 提供的 Web 應用程序。要在我們的 HTML 客戶(hù)端頁(yè)中使用 Dojo,我們需要使用清單 8 中所示的腳本導入 dojo.js 腳本。


清單 8:導入 dojo.js
            <script type="text/javascript" src="/dojo/dojo/dojo.js"            djConfig="isDebug:false, parseOnLoad: true"></script>            

導入 Dojo 腳本時(shí),我們可以通過(guò) dojo.require 調用導入其余依賴(lài)項。我們要創(chuàng )建的 dojox.Grid 小部件需要模型和結構。其模型代表要顯示的數據,而結構代表我們將要如何進(jìn)行顯示。此模型實(shí)際上是由數組組成的數組。清單 9 顯示了結構定義:


清單 9:模型定義
            var view1 = {            noscroll :false,            cells : [ [ {            name :'Symbol',            width :'auto'            }, {            name :'Company Name',            width :'auto'            }, {            name :'Price',            width :'auto'            }, {            name :'Earnings Per Share',            width :'auto'            } ] ]            };            var gridLayout = [ {            type :'dojox.GridRowView',            width :'20px'            }, view1 ];            <div class="tundra" id="stock_grid" dojoType="dojox.Grid" model="updatedModel"            structure="gridLayout" elasticView="1" defaultHeight="37em"></div>            

在此清單中,我們發(fā)現帶 id="stock_grid"div 封裝了實(shí)際的網(wǎng)格。此結構由 gridLayout 對象定義,此對象是包含 view1 的數組。

view1 變量也是數組,其中包含提供所有列應該在網(wǎng)格中如何顯示的詳細信息的 cells 屬性。


構建并部署 Web 應用程序

要構建此應用程序,您將需要 Apache Maven2。安裝 Maven2 并按照以下步驟構建應用程序:

  1. 提取 ticker.zip 存檔,這將創(chuàng )建名為 ticker 的目錄。
  2. 打開(kāi)命令 Shell,并將當前目錄更改為 ticker。
  3. 運行 mvn install。這將構建應用程序,并將輸出 WAR 文件放入 ticker 下的 target 目錄中。WAR 文件的名稱(chēng)為 ticker.war。
  4. 在瀏覽器中打開(kāi) Community Edition 控制臺,并導航到 Deploy New Portlet。
  5. Archive 文本框中,輸入所生成 ticker.war 的路徑,并單擊 Install。

測試 Web 應用程序

  1. 在 Web 瀏覽器中打開(kāi) http://localhost:8080/ticker,以打開(kāi)股票報價(jià)器,如圖 4 中所示。

    圖 4. 瀏覽器中運行的股票報價(jià)器


  2. 在 Web 瀏覽器中打開(kāi) http://localhost:8080/ticker/comet,以查看 Comet Servlet 的輸出,如圖5 中所示。

    圖 5. Comet Servlet 輸出



結束語(yǔ)

在本文中,我們通過(guò)管理控制臺創(chuàng )建并配置了嵌入在 Community Edition 中的 Tomcat 實(shí)例的 NIO 連接器。我們還開(kāi)發(fā)了一個(gè) Java EE Web 應用程序,使用 DWR 的 Reverse Ajax 功能將來(lái)自服務(wù)器的數據通過(guò) NIO 連接器中內置的 Comet 支持推送到瀏覽器。最后,我們了解了如何實(shí)現 Tomcat 的 CometProcessor 接口來(lái)編寫(xiě)公開(kāi)其 Comet 功能的 Servlet。

致謝

感謝 Phani Madgula 和 Ashish Jain 對本文進(jìn)行了審閱。 

本站僅提供存儲服務(wù),所有內容均由用戶(hù)發(fā)布,如發(fā)現有害或侵權內容,請點(diǎn)擊舉報。
打開(kāi)APP,閱讀全文并永久保存 查看更多類(lèi)似文章
猜你喜歡
類(lèi)似文章
Struts2的Ajax支持介紹
Tomcat服務(wù)器原理詳解
Ajax簡(jiǎn)介
面向 Java 開(kāi)發(fā)人員的 Ajax: 使用 Jetty 和 Direct Web Rem...
Servlet/JSP深入詳解:基于Tomcat的Web開(kāi)發(fā)第一章02
tomcat開(kāi)發(fā)技術(shù)之與http服務(wù)器的集成 (1)
更多類(lèi)似文章 >>
生活服務(wù)
分享 收藏 導長(cháng)圖 關(guān)注 下載文章
綁定賬號成功
后續可登錄賬號暢享VIP特權!
如果VIP功能使用有故障,
可點(diǎn)擊這里聯(lián)系客服!

聯(lián)系客服

欧美性猛交XXXX免费看蜜桃,成人网18免费韩国,亚洲国产成人精品区综合,欧美日韩一区二区三区高清不卡,亚洲综合一区二区精品久久