新聞中心

EEPW首頁 > 嵌入式系統(tǒng) > 設(shè)計應(yīng)用 > 基于J2ME的防汛信息系統(tǒng)的研究

基于J2ME的防汛信息系統(tǒng)的研究

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

在本系統(tǒng)中,客戶端和服務(wù)器之間主要通過HTTP協(xié)議進行通信,工作流程如下:

(1) 用戶啟動手機上的MIDlet進入登錄界面,輸入用戶名和密碼進行登錄。MIDlet用Connector類的open方法建立一個到服務(wù)器端的連接,并把這個連接強制轉(zhuǎn)換成為HttpConnection類型。

(2) 客戶端用HttpConnection類的openInputStream方法和openOutputStream方法來返回輸入輸出流并通過它們來發(fā)送請求和接收響應(yīng)信息。

(3) 服務(wù)器端接收到客戶端的連接請求后,把它封裝成一個HttpServletRequest對象,調(diào)用相應(yīng)的Servlet,通過EJB或JavaBean訪問數(shù)據(jù)庫,并把處理結(jié)果返回客戶端的MIDlet。

(4) 客戶端MIDlet使用輸入流接收服務(wù)器端返回的結(jié)果,根據(jù)返回的是”station”(測站)、”person”(普通用戶)還是”none”(無此用戶)而在屏幕上呈現(xiàn)不同的界面。

(5) 登錄成功后,MIDlet重新建立HttpConnection來進行數(shù)據(jù)更新或查詢操作。

四、技術(shù)難點和解決方案

4.1 用戶定制信息的接收

用戶定制的信息有兩種發(fā)送的方式:

(1)定時發(fā)送。用于把用戶定制的日常信息每天定時發(fā)送給用戶。

(2)緊急發(fā)送。當(dāng)出現(xiàn)緊急汛情時即時把信息發(fā)送到相關(guān)的責(zé)任人。

在客戶端,對相關(guān)信息的接收是通過的PUSH注冊功能來實現(xiàn)的。Push技術(shù)是一種能夠使得Midlet應(yīng)用程序不需要用戶的操作而自行啟動運行的機制。在通常的網(wǎng)絡(luò)連接中,是客戶端主動去連接服務(wù)器,服務(wù)器接受請求并把處理結(jié)果返回客戶端。而Push技術(shù)不同,它不需要應(yīng)用程序通過“拉(pull)”的方式通過網(wǎng)絡(luò)取得數(shù)據(jù),客戶端需要的數(shù)據(jù)會被主動“推(push)”向客戶端的移動設(shè)備。當(dāng)移動設(shè)備接收到信息時,相關(guān)的Midlet會被激活并開始運行,處理發(fā)送過來的數(shù)據(jù)。

服務(wù)器端使用Socket可以自動向與其相聯(lián)的客戶端發(fā)送數(shù)據(jù),這就為Push技術(shù)提供了保證。先由客戶端的 MIDlet注冊好服務(wù)類型,地址,端口號,當(dāng)服務(wù)器端檢測到有緊急情況發(fā)生或用戶定制的情況發(fā)生時,就會將相應(yīng)的消息通過Socket發(fā)送到客戶端,客戶端會啟動相應(yīng)的MIDlet對該消息進行相應(yīng)處理。

平臺從MIDP2.0開始增加了對Push注冊的支持。Push機制可以通過如下兩種方式激活Midlet:一種是接入的網(wǎng)絡(luò)連接的,當(dāng)客戶端接收到網(wǎng)絡(luò)Push來的信息后就自動啟動Midlet運行;另一種是計時器的警告通知,當(dāng)。Push 注冊機制可以使MIDlet 自動運行,運行方式有兩種:一種定時技術(shù),當(dāng)?shù)竭_特定時間,程序就會運行;另一種基于網(wǎng)絡(luò),當(dāng)設(shè)備受到網(wǎng)絡(luò)推送的信息時,可以啟動程序運行。本系統(tǒng)采用第一種方式來實現(xiàn)定制信息的發(fā)送。

要在客戶端使用Push技術(shù),必須事先進行Push注冊。Push注冊有兩個方法:靜態(tài)注冊和動態(tài)注冊。靜態(tài)注冊需要將 Push注冊信息添加到JAD文件中,在Midlet Suite安裝時完成注冊。靜態(tài)注冊的缺點是必須通過Midlet Suite安裝過程來實現(xiàn),一但安裝好后就無法添加新的注冊,同時如果要取消Push注冊,也必須卸載Midlet Suite。動態(tài)注冊是MIDlet通過Push Registry接口API來實現(xiàn)的,可以在程序運行時添加或取消Push注冊,增加了靈活性。本文采用了動態(tài)注冊的方法。

在動態(tài)注冊時MIDlet需要告訴AMS它所要連接的服務(wù)器的IP地址、端口號和要啟動的MIDlet類,實現(xiàn)代碼如下:

String midletClassName=”com.water.PushInfo”;//這是自動運行處理數(shù)據(jù)的Midlet
String ConnectionURL =”socket://:6789”;
String AllowedSender=”*”;//*表示允許接收任意地址發(fā)送的信息
PushRegistry.registerConnection(midletClassName, ConnectionURL, AllowedSender);
…..

這樣,當(dāng)AMS監(jiān)測到端口號為6789的Socket服務(wù)器發(fā)送來的數(shù)據(jù)后,就會啟動com.water包下的PushInfo來處理這些數(shù)據(jù)。

取消注冊可以使用PushRegistry.unregisterConnection(ConnectionURL)來完成。

4.2 數(shù)據(jù)庫連接池技術(shù)

本例采用了數(shù)據(jù)庫連接池技術(shù)。傳統(tǒng)的Web應(yīng)用程序進行數(shù)據(jù)庫操作時一般要經(jīng)過(1)建立數(shù)據(jù)庫連接;(2)進行數(shù)據(jù)庫的增加、刪除、修改、查詢操作;(3)斷開數(shù)據(jù)庫連接這三個步驟。這種方式有一個重要的缺點:要為每個Web請求建立一次數(shù)據(jù)庫連接并對其進行管理,這些操作都會耗費大量的時間和資源。數(shù)據(jù)庫連接池的基本思想是預(yù)先建立一些連接,放置在內(nèi)存對象中以備使用。當(dāng)程序中需要建立數(shù)據(jù)庫連接時,只需從內(nèi)存中取出一個來用而不用重新建一個連接。同樣,使用完畢后,只需將此連接放回到內(nèi)存中即可,而連接的建立和斷開都由連接池自身來管理。Weblogic服務(wù)器提供了圖形化的界面來建立數(shù)據(jù)庫連接池,設(shè)置比較簡單。建立好數(shù)據(jù)庫連接池和數(shù)據(jù)源后,就可以在Servlet中通過JavaBean或EJB來調(diào)用,代碼如下:

Hashtable ht = new Hashtable();
ht.put(Context.INITIAL_CONTEXT_FACTORY,weblogic.jndi.WLInitialContextFactory);
ht.put(Context.PROVIDER_URL,t3://localhost:7001);
try
{
Context ctx=new InitialContext(ht);
DataSource ds=(DataSource)ctx.lookup(WaterJNDI);
Connection con=ds.getConnection();

}catch(Exception e){

}



評論


相關(guān)推薦

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

關(guān)閉