- 相關(guān)推薦
j2ee企業(yè)級應用開發(fā)
企業(yè)級應用是指那些為商業(yè)組織、大型企業(yè)而創(chuàng)建并部署的解決方案及應用。下面是小編整理的關(guān)于j2ee企業(yè)級應用開發(fā),希望大家認真閱讀!
當代的企業(yè)級應用決不可能是一個個的獨立系統(tǒng)。在企業(yè)中,一般都會部署多個彼此連接的、相互通過不同集成層次進行交互的企業(yè)級應用,同時這些應用又都有可能與其它企業(yè)的相關(guān)應用連接,從而構(gòu)成一個結(jié)構(gòu)復雜的、跨越Intranet和Internet的分布式企業(yè)應用群集。其中,連接企業(yè)內(nèi)部各種應用的技術(shù)稱為EAI(Enterprise Application Integration, 企業(yè)應用集成),而連接企業(yè)間各種應用的技術(shù)稱為B2BI(Business-To-Business Integration, 企業(yè)間集成),采用EAI、B2BI技術(shù)及早先的N層體系架構(gòu)就是當今企業(yè)級應用的最大特征。
此外,作為企業(yè)級應用,其不但要有強大的功能,還要能夠滿足未來業(yè)務需求的變化,易于升級和維護。
企業(yè)級應用架構(gòu)
下面我們使用一個圖示來簡單地解析一下企業(yè)級應用的架構(gòu),見圖1。
圖1 企業(yè)級應用的體系架構(gòu)
這個體系架構(gòu)的主體是MVC架構(gòu)。MVC是Model/View/Control的縮寫。Model/View/Control是軟件設(shè)計的典型結(jié)構(gòu)。在這種設(shè)計結(jié)構(gòu)下,一個應用被分為三個部分:Model、View和Controller,每個部分負責不同的功能。Model是指對業(yè)務數(shù)據(jù)/信息的處理模塊,包括對業(yè)務數(shù)據(jù)的存取、加工、綜合等;View是指用戶界面,也就是面向用戶的數(shù)據(jù)表示;Controller則負責View和Model之間的流程控制,也就是完成兩個方向的動作:1.將用戶界面(View)的操作映射到具體的Model,以完成具體的業(yè)務邏輯;2. 將通過Model處理完的業(yè)務數(shù)據(jù)及時反應到用戶界面(View)上。
MVC架構(gòu)使得應用程序的結(jié)構(gòu)更加清晰,通過將代碼按照層次劃分為業(yè)務邏輯/數(shù)據(jù)、用戶界面和應用流程控制這三個層次,增強代碼穩(wěn)定性。我們知道,對于Model、View、Controller這三部分功能來講,View的實現(xiàn)一般是由界面設(shè)計人員和界面程序員來完成,Model則是由業(yè)務邏輯程序員來完成,Controller則一般由負責整體控制的程序員來完成。Controller部分的代碼比較穩(wěn)定,一般會實現(xiàn)一個通用的架構(gòu);而Model則跟隨商務流程的變化而變化;View的更改則是隨著用戶需求的更改而更改。這種模塊功能的劃分有利于在代碼修改過程中進行模塊的隔離,而不需要把具有不同功能的代碼混雜在一起造成混亂。對于項目開發(fā)而言,有利于在項目小組內(nèi)按照小組成員各自的擅長進行分工,有利于三個部分并行開發(fā)、加快項目進度。
企業(yè)級資源連接
對于Model部分,也就是業(yè)務邏輯的處理部分,一般總是對商務數(shù)據(jù)進行處理、加工、綜合等。對于企業(yè)級應用而言,商袷?縈辛街擲叢矗?恢質(zhì)鞘?菘猓?硪恢衷蚴瞧淥?鈉笠導隊τ孟低場?lt;BR>
對于數(shù)據(jù)庫而言,這應當是大家熟悉的領(lǐng)域。我們通過使用數(shù)據(jù)庫驅(qū)動程序,利用SQL來查詢、操縱數(shù)據(jù)庫。而對于其它的企業(yè)級應用而言,一般這些應用都會提供API,通過這些API,其它的應用就能夠存取訪問其中的數(shù)據(jù),甚至是觸發(fā)這些企業(yè)級應用中的一些業(yè)余流程。
企業(yè)級平臺的特征
企業(yè)級應用需要使用優(yōu)秀的企業(yè)級應用體系結(jié)構(gòu),而優(yōu)秀的企業(yè)級應用體系結(jié)構(gòu)通常來自于優(yōu)秀的解決方案。應用程序設(shè)計開始就要考慮其體系結(jié)構(gòu)的合理性、靈活性、健壯性,從而既可滿足企業(yè)級應用的復雜需求,也能為今后系統(tǒng)的調(diào)整和升級留有余地。體系結(jié)構(gòu)影響了整個應用的生命周期,實際上能夠延長整個應用的生命周期,同時增強了用戶在多變的商業(yè)社會中的適應性,減少了系統(tǒng)維護的開銷和難度,從而給用戶帶來最大的利益。
一個理想的企業(yè)級應用系統(tǒng)平臺應該具有如下特征:
◆ 部署、開發(fā)和維護的有效性;
◆ 系統(tǒng)運行的健壯性和可靠性;
◆ 具備失敗恢復的能力;
◆ 能夠處理海量的數(shù)據(jù);
◆ 能夠同時支持數(shù)百個用戶;
◆ 具備很高的安全性;
◆ 數(shù)據(jù)的高可用性;
◆ 可以迅速地開發(fā)和部署新的應用程序;
◆ 簡化組件重用;
◆ 直觀的編程模型;
◆ 支持行業(yè)標準和通用編程接口;
◆ 適用與小、中、大各種規(guī)模的應用系統(tǒng);
◆ 系統(tǒng)費用隨系統(tǒng)規(guī)模的增長而線性增長;
◆ 不斷進行技術(shù)升級,以滿足不斷涌現(xiàn)的需求。
使用J2EE架構(gòu)企業(yè)級應用
為了滿足架構(gòu)企業(yè)級應用的需求,Java的創(chuàng)始人Sun公司在早期的J2SE(Java 2 Platform Standard Edition)基礎(chǔ)上,針對企業(yè)級應用的各種需求,主導并創(chuàng)造了J2EE(Java 2 Platform Enterprise Edition)。
那么到底什么是J2EE呢?從整體上講,J2EE是使用Java技術(shù)開發(fā)企業(yè)級應用的一種事實上的工業(yè)標準(Sun公司出于其自身利益的考慮,至今沒有將Java及其相關(guān)技術(shù)納入標準化組織的體系),它是Java技術(shù)不斷適應和促進企業(yè)級應用過程中的產(chǎn)物。目前,Java平臺有三個版本:適用于小型設(shè)備和智能卡的J2ME(Java 2 Platform Micro Edition)、適用于桌面系統(tǒng)的J2SE和適用于企業(yè)級應用的J2EE。Sun推出J2EE的目的是為了克服傳統(tǒng)Client/Server模式的弊病,迎合Browser/Server架構(gòu)的潮流,為應用Java技術(shù)開發(fā)服務器端應用提供一個平臺可移植的、多用戶的、獨立的、安全的和基于標準的企業(yè)級平臺,從而簡化企業(yè)應用的開發(fā)、管理和部署。J2EE是一個標準,而不是一個現(xiàn)成的產(chǎn)品。各個平臺開發(fā)商按照J2EE規(guī)范分別開發(fā)了不同的J2EE應用服務器,J2EE應用服務器是J2EE企業(yè)級應用的部署平臺。由于它們都遵循了J2EE規(guī)范,因此,使用J2EE技術(shù)開發(fā)的企業(yè)級應用可以部署在各種J2EE應用服務器上。
為了推廣并規(guī)范化使用J2EE架構(gòu)企業(yè)級應用的體系架構(gòu),Sun同時給出了一個建議性的J2EE應用設(shè)計模型:J2EE Blueprints。J2EE Blueprints提供了實施J2EE企業(yè)級應用的體系架構(gòu)、設(shè)計模式和相關(guān)的代碼,通過應用J2EE Blueprints所描述的體系模型,能夠部分簡化架構(gòu)企業(yè)級應用這項復雜的工作。J2EE Blueprints是開發(fā)人員設(shè)計和優(yōu)化J2EE組件的基本原則,同時為圍繞開發(fā)工作進行職能分工給出了指導性策略,以幫助應用開發(fā)設(shè)計人員合理地分配技術(shù)資源。
下面我們參照J2EE Blueprints,結(jié)合最新版的J2EE規(guī)范(J2EE 1.4),從整體上闡述如何使用J2EE架構(gòu)企業(yè)級應用。
圖2 使用J2EE架構(gòu)企業(yè)級應用的體系架構(gòu)
圖2給出了使用J2EE架構(gòu)企業(yè)級應用的體系架構(gòu)。J2EE將組成一個完整企業(yè)級應用的不同部分納入不同的容器(Container),每個容器中都包含若干組件(這些組件是需要部署在相應容器中的),同時各種組件都能使用各種J2EE Service/API。J2EE容器包括:
◆ Web容器 服務器端容器,包括兩種組件JSP和Servlet,JSP和Servlet都是Web服務器的功能擴展,接受Web請求,返回動態(tài)的Web頁面。Web容器中的組件可使用EJB容器中的組件完成復雜的商務邏輯。
◆ EJB容器 服務器端容器,包含的組件為EJB(Enterprise JavaBeans),它是J2EE的核心之一,主要用于服務器端的商業(yè)邏輯的實現(xiàn)。EJB規(guī)范定義了一個開發(fā)和部署分布式商業(yè)邏輯的框架,以簡化企業(yè)級應用的開發(fā),使其較容易地具備可伸縮性、可移植性、分布式事務處理、多用戶和安全性等。
◆ Applet容器 客戶端容器,包含的組件為Applet。Applet是嵌在瀏覽器中的一種輕量級客戶端,一般而言,僅當使用Web頁面無法充分地表現(xiàn)數(shù)據(jù)或應用界面的時候,才使用它。Applet是一種替代Web頁面的手段,我們僅能夠使用J2SE開發(fā)Applet,Applet無法使用J2EE的各種Service和API,這是為了安全性的考慮。
◆ Application Client容器 客戶端容器,包含的組件為Application Client。Application Client相對Applet而言是一種較重量級的客戶端,它能夠使用J2EE的大多數(shù)Service和API。
通過這四個容器,J2EE能夠靈活地實現(xiàn)前面描述的企業(yè)級應用的架構(gòu)。
在View部分,J2EE提供了三種手段:Web容器中的JSP(或Servlet)、Applet和Application Client,分別能夠?qū)崿F(xiàn)面向瀏覽器的數(shù)據(jù)表現(xiàn)和面向桌面應用的數(shù)據(jù)表現(xiàn)。Web容器中的Servlet是實現(xiàn)Controller部分業(yè)務流程控制的主要手段;而EJB則主要針對Model部分的業(yè)務邏輯實現(xiàn)。至于與各種企業(yè)資源和企業(yè)級應用相連接,則是依靠J2EE的各種服務和API。
在J2EE的各種服務和API中,JDBC和JCA用于企業(yè)資源(各種企業(yè)信息系統(tǒng)和數(shù)據(jù)庫等)的連接,JAX-RPC、JAXR和SAAJ則是實現(xiàn)Web Services和Web Services連接的基本支持。
J2EE的各種組件
我們就J2EE的各種組件、服務和API,進行更加詳細的闡述,看看在開發(fā)不同類型的企業(yè)級應用時,根據(jù)各自需求和目標的不同,應當如何靈活使用并組合不同的組件和服務。
· Servlet
Servlet是Java平臺上的CGI技術(shù)。Servlet在服務器端運行,動態(tài)地生成Web頁面。與傳統(tǒng)的CGI和許多其它類似CGI的技術(shù)相比,Java Servlet具有更高的效率并更容易使用。對于Servlet,重復的請求不會導致同一程序的多次轉(zhuǎn)載,它是依靠線程的方式來支持并發(fā)訪問的。
· JSP
JSP(Java Server Page)是一種實現(xiàn)普通靜態(tài)HTML和動態(tài)頁面輸出混合編碼的技術(shù)。從這一點來看,非常類似Microsoft ASP、PHP等技術(shù)。借助形式上的內(nèi)容和外觀表現(xiàn)的分離,Web頁面制作的任務可以比較方便地劃分給頁面設(shè)計人員和程序員,并方便地通過JSP來合成。在運行時態(tài),JSP將會被首先轉(zhuǎn)換成Servlet,并以Servlet的形態(tài)編譯運行,因此它的效率和功能與Servlet相比沒有差別,一樣具有很高的效率。
· EJB
EJB定義了一組可重用的組件:Enterprise Beans。開發(fā)人員可以利用這些組件,像搭積木一樣建立分布式應用。在裝配組件時,所有的Enterprise Beans都需要配置到EJB服務器(一般的Weblogic、WebSphere等J2EE應用服務器都是EJB服務器)中。EJB服務器作為容器和低層平臺的橋梁管理著EJB容器,并向該容器提供訪問系統(tǒng)服務的能力。所有的EJB實例都運行在EJB容器中。EJB容器提供了系統(tǒng)級的服務,控制了EJB的生命周期。EJB容器為它的開發(fā)人員代管了諸如安全性、遠程連接、生命周期管理及事務管理等技術(shù)環(huán)節(jié),簡化了商業(yè)邏輯的開發(fā)。EJB中定義了三種Enterprise Beans:
◆ Session Beans
◆ Entity Beans
◆ Message-driven Beans
· JDBC
JDBC(Java Database Connectivity,Java數(shù)據(jù)庫連接)API是一個標準SQL(Structured Query Language,結(jié)構(gòu)化查詢語言)數(shù)據(jù)庫訪問接口,它使數(shù)據(jù)庫開發(fā)人員能夠用標準Java API編寫數(shù)據(jù)庫應用程序。JDBC API主要用來連接數(shù)據(jù)庫和直接調(diào)用SQL命令執(zhí)行各種SQL語句。利用JDBC API可以執(zhí)行一般的SQL語句、動態(tài)SQL語句及帶IN和OUT參數(shù)的存儲過程。Java中的JDBC相當與Microsoft平臺中的ODBC(Open Database Connectivity)。
· JMS
JMS(Java Message Service,Java消息服務)是一組Java應用接口,它提供創(chuàng)建、發(fā)送、接收、讀取消息的服務。JMS API定義了一組公共的應用程序接口和相應語法,使得Java應用能夠和各種消息中間件進行通信,這些消息中間件包括IBM MQ-Series、Microsoft MSMQ及純Java的SonicMQ。通過使用JMS API,開發(fā)人員無需掌握不同消息產(chǎn)品的使用方法,也可以使用統(tǒng)一的JMS API來操縱各種消息中間件。通過使用JMS,能夠最大限度地提升消息應用的可移植性。 JMS既支持點對點的消息通信,也支持發(fā)布/訂閱式的消息通信。
· JNDI
由于J2EE應用程序組件一般分布在不同的機器上,所以需要一種機制以便于組件客戶使用者查找和引用組件及資源。在J2EE體系中,使用JNDI(Java Naming and Directory Interface)定位各種對象,這些對象包括EJB、數(shù)據(jù)庫驅(qū)動、JDBC數(shù)據(jù)源及消息連接等。JNDI API為應用程序提供了一個統(tǒng)一的接口來完成標準的目錄操作,如通過對象屬性來查找和定位該對象。由于JNDI是獨立于目錄協(xié)議的,應用還可以使用JNDI訪問各種特定的目錄服務,如LDAP、NDS和DNS等。
· JTA
JTA(Java Transaction API)提供了J2EE中處理事務的標準接口,它支持事務的開始、回滾和提交。同時在一般的J2EE平臺上,總提供一個JTS(Java Transaction Service)作為標準的事務處理服務,開發(fā)人員可以使用JTA來使用JTS。
· JCA
JCA(J2EE Connector Architecture)是J2EE體系架構(gòu)的一部分,為開發(fā)人員提供了一套連接各種企業(yè)信息系統(tǒng)(EIS,包括ERP、SCM、CRM等)的體系架構(gòu),對于EIS開發(fā)商而言,它們只需要開發(fā)一套基于JCA的EIS連接適配器,開發(fā)人員就能夠在任何的J2EE應用服務器中連接并使用它;贘CA的連接適配器的實現(xiàn),需要涉及J2EE中的事務管理、安全管理及連接管理等服務組件。
· JMX
JMX(Java Management Extensions)的前身是JMAPI。JMX致力于解決分布式系統(tǒng)管理的問題。JMX是一種應用編程接口、可擴展對象和方法的集合體,可以跨越各種異構(gòu)操作系統(tǒng)平臺、系統(tǒng)體系結(jié)構(gòu)和網(wǎng)絡傳輸協(xié)議,開發(fā)無縫集成的面向系統(tǒng)、網(wǎng)絡和服務的管理應用。JMX是一個完整的網(wǎng)絡管理應用程序開發(fā)環(huán)境,它同時提供了廠商需要收集的完整的特性清單、可生成資源清單表格、圖形化的用戶接口;訪問SNMP的網(wǎng)絡API;主機間遠程過程調(diào)用;數(shù)據(jù)庫訪問方法等。
· JAAS
JAAS(Java Authentication and Authorization Service)實現(xiàn)了一個Java版本的標準Pluggable Authentication Module(PAM)的框架。JAAS可用來進行用戶身份的鑒定,從而能夠可靠并安全地確定誰在執(zhí)行Java代碼。同時JAAS還能通過對用戶進行授權(quán),實現(xiàn)基于用戶的訪問控制。
· JACC
JACC(Java Authorization Service Provider Contract for Containers)在J2EE應用服務器和特定的授權(quán)認證服務器之間定義了一個連接的協(xié)約,以便將各種授權(quán)認證服務器插入到J2EE產(chǎn)品中去。
· JAX-RPC
通過使用JAX-RPC(Java API for XML-based RPC),已有的Java類或Java應用都能夠被重新包裝,并以Web Services的形式發(fā)布。JAX-RPC提供了將RPC參數(shù)(in/out)編碼和解碼的API,使開發(fā)人員可以方便地使用SOAP消息來完成RPC調(diào)用。同樣,對于那些使用EJB(Enterprise JavaBeans)的商業(yè)應用而言,同樣可以使用JAX-RPC來包裝成Web服務,而這個Web Servoce的WSDL界面是與原先的EJB的方法是對應一致的。JAX-RPC為用戶包裝了Web服務的部署和實現(xiàn),對Web服務的開發(fā)人員而言,SOAP/WSDL變得透明,這有利于加速Web服務的開發(fā)周期。
· JAXR
JAXR(Java API for XML Registries)提供了與多種類型注冊服務進行交互的API。JAXR運行客戶端訪問與JAXR規(guī)范相兼容的Web Servcices,這里的Web Services即為注冊服務。一般來說,注冊服務總是以Web Services的形式運行的。JAXR支持三種注冊服務類型:JAXR Pluggable Provider、Registry-specific JAXR Provider、JAXR Bridge Provider(支持UDDI Registry和ebXML Registry/Repository等)。
· SAAJ
SAAJ(SOAP with Attachemnts API for Java)是JAX-RPC的一個增強,為進行低層次的SOAP消息操縱提供了支持。
企業(yè)級應用示例
下面我們通過假設(shè)一個企業(yè)應用的J2EE實現(xiàn),來了解各種組件和服務的應用。假設(shè)應用對象是計算機產(chǎn)品的生產(chǎn)商/零售商的銷售系統(tǒng),這個銷售系統(tǒng)能夠通過自己的網(wǎng)站發(fā)布產(chǎn)品信息,同時也能將產(chǎn)品目錄傳送給計算機產(chǎn)品交易市場。銷售系統(tǒng)能夠在線接受訂單(來自自己的Web網(wǎng)站或者來自計算機產(chǎn)品交易市場),并隨后轉(zhuǎn)入內(nèi)部企業(yè)管理系統(tǒng)進行相關(guān)的后續(xù)處理。
參見圖3,這個企業(yè)應用可以這種方式架構(gòu)。該企業(yè)應用的核心是產(chǎn)品目錄管理和產(chǎn)品定購管理這兩個業(yè)務邏輯,使用EJB加以實現(xiàn),并部署在EJB容器中。由于產(chǎn)品目錄和定購信息都需要持久化,因此使用JDBC連接數(shù)據(jù)庫,并使用JTA來完成數(shù)據(jù)庫存取事務。
圖3 J2EE應用示例
然后使用JSP/Servlet來實現(xiàn)應用的Web表現(xiàn):在線產(chǎn)品目錄瀏覽和在線定購。為了將產(chǎn)品目錄發(fā)送給特定的交易市場,使用JMS實現(xiàn)異步的基于消息的產(chǎn)品目錄傳輸。為了使得更多的其它外部交易市場能夠集成產(chǎn)品目錄和定購業(yè)務,需要使用Web Services技術(shù)包裝商業(yè)邏輯的實現(xiàn)。由于產(chǎn)品定購管理需要由公司內(nèi)部雇員進行處理,因此需要集成公司內(nèi)部的用戶系統(tǒng)和訪問控制服務以方便雇員的使用,使用JACC集成內(nèi)部的訪問控制服務,使用JNDI集成內(nèi)部的用戶目錄,并使用JAAS進行訪問控制。由于產(chǎn)品訂購事務會觸發(fā)后續(xù)的企業(yè)ERP系統(tǒng)的相關(guān)操作(包括倉儲、財務、生產(chǎn)等),需要使用JCA連接企業(yè)ERP。
最后為了將這個應用納入到企業(yè)整體的系統(tǒng)管理體系中去,使用Application Client架構(gòu)了一個管理客戶端(與其它企業(yè)應用管理應用部署在一臺機器上),并通過JMX管理這個企業(yè)應用。
【j2ee企業(yè)級應用開發(fā)】相關(guān)文章:
Quartz開發(fā)企業(yè)級任務調(diào)度應用08-22
j2ee應用技術(shù)開發(fā)結(jié)構(gòu)10-21
J2EE開發(fā)原則10-18
J2EE應用的核心策略10-30
Eclipse j2ee開發(fā)環(huán)境的搭建07-27
J2EE項目開發(fā)風險匯總08-03
高性能J2EE應用的技巧07-21