EJB的分類及其各自的功能和應用
在EJB2.0中對定義了三種不同類別的EJB分類:Session Bean(會話Bean)、Entity Bean(實體Bean)和Message-Driven Bean(消息驅動Bean)。
1 EJB分類之會話Bean
會話Bean是商務過程對象,執(zhí)行商務邏輯、規(guī)則和工作流程。會話Bean之所以被稱為會話Bean,是因為它代表的是一個動作、是一個過程,它的生存期就是調用它的客戶端與它進行會話的過程。
會話Bean根據(jù)其是否保存客戶的狀態(tài),又分為狀態(tài)會話Bean和無狀態(tài)會話Bean。狀態(tài)會話Bean是一種保持會話狀態(tài)的服務,每個實例都與特定的客戶機相關聯(lián),在與客戶機的方法調用之間維持對話狀態(tài)。與之相反,無狀態(tài)會話Bean不保存與特定客戶的對話狀態(tài)。因此狀態(tài)會話Bean比無狀態(tài)會話 Bean具有更多的功能,而無狀態(tài)會話Bean實例可以通過 EJB容器自由地在客戶機之間交換,從而少量的會話Bean就可以服務于大量的客戶機。
2 EJB分類之實體Bean
實體Bean代表商務上的實體,比如商務數(shù)據(jù),應該包含與數(shù)據(jù)相關的邏輯。實體Bean是對應到數(shù)據(jù)庫中的一個視圖,一個實體Bean實例和底層數(shù)據(jù)庫完全是一回事。因此,一個簡單的實體bean實例代表一個特殊的記錄。更復雜的實體bean可以代表數(shù)據(jù)庫表間關聯(lián)視圖。
實體Bean有兩種操作類型:BMP(Bean管理持久性)和CMP(容器管理持久性)。BMP是指由Bean自己來實現(xiàn)實體Bean的持久性,即在 Bean中實現(xiàn)數(shù)據(jù)庫操作。而CMP則是由容器實現(xiàn)Bean的持久性,使我們不需要在Bean內再編寫數(shù)據(jù)庫操作的代碼。
3 EJB分類之消息驅動Bean
消息驅動Bean是EJB2.0新引入的一種Bean類型。它的主要目的是,通過允許容器去聚合并且管理消息驅動Bean實例,以此來提供傳入JMS消息的并發(fā)處理。
4 會話Bean與實體Bean的區(qū)別和聯(lián)系
會話Bean執(zhí)行應用邏輯,它們隱含地使用實體Bean作為它們操作的數(shù)據(jù)。在EJB分布式對象體系結構中,會話Bean被用做代表實際商務過程的高層接口來屏蔽底層實體Bean子系統(tǒng)。實體Bean是實際恒定商務實體的模型,因此它通常比會話Bean具有更高層次的重復使用。
5 EJB的應用
接下來,通過分析電子購物環(huán)節(jié)的業(yè)務邏輯層的對象模型來說明各種EJB在業(yè)務邏輯層中的不同應用。
業(yè)務邏輯層包含了一系列EJB組件。首先我們將其抽象成若干個對象模型,如圖所示:
圖:對象模型圖
本圖首先反映了電子商務中各EJB組件之間的靜態(tài)關系。
由多個購物籃條目(Cart Line Item)組成的一個購物籃(Cart)為一個顧客 (Customer)存儲產(chǎn)品的臨時選擇;由多個訂單條目(Order line Item)組成的一個訂單(Order)為一個顧客存儲產(chǎn)品的永久選擇。購物籃能將自身轉換為訂單。
一個購物籃條目代表一個產(chǎn)品(Product)的臨時選擇,一個訂單條目代表一個產(chǎn)品的永久選擇。
估價器(Pricer)在顧客查看購物籃時計算購物籃的價格,并且在顧客最終生成訂單時計算訂單的價格。
訂單處理器(Order Processor)為訂單驗證信用卡,發(fā)送E-mail確認,并標識為永久。
同時從本圖中也可以了解一個電子購物的過程:首先,在購物時顧客把自己感興趣的產(chǎn)品放入購物籃中,同時由估價器對購物籃進行及時估價。然后,顧客在確認購買后,購物籃能自動生成訂單。再由估價器計算出訂單的價格。接著,由訂單處理器驗證顧客信用卡的合法性,在交易完成后為顧客發(fā)送E-mail確認交易成功,并將本交易標識為永久。
顧客、訂單、產(chǎn)品、訂單條目這幾個對象是永久性、持續(xù)性對象,例如,顧客信息、產(chǎn)品信息都需要存入數(shù)據(jù)庫,并且在適當?shù)臅r候從數(shù)據(jù)庫中讀取。所以,這幾項都需要用實體Bean來實現(xiàn)。
購物籃和購物籃條目只在顧客購物的過程中起作用,所以不是永久性的,而且每一個購物籃都對應于一個特定的顧客,對應于若干條特定的購物車條目,因此購物籃和購物籃條目用狀態(tài)會話Bean來充當最合適不過。
估價器的作用是計算出購物籃和訂單的價格,它并沒有和特定的顧客綁定,可以作用于任意的購物籃,而且也不是永久對象,因此估價器可以用一個無狀態(tài)會話Bean來充當。
訂單處理器是一個特殊的對象,它通過顧客所要求的不同的付款方式產(chǎn)生不同的訂單,也就是說,它是由不同的付款方式來驅動的。所以在這里用消息驅動Bean是最恰當?shù)摹?/P>
【編輯推薦】