Java最初是在瀏覽器和客戶端機器中粉墨登場的。當時,很多人質疑它是否適合做服務器端的開發(fā)。現(xiàn)在,隨著對Java2平臺企業(yè)版(J2EE)第三方支持的增多,Java被廣泛接納為開發(fā)企業(yè)級服務器端解決方案的首選平臺之一。
成都創(chuàng)新互聯(lián)公司主要從事成都網(wǎng)站設計、成都網(wǎng)站制作、網(wǎng)頁設計、企業(yè)做網(wǎng)站、公司建網(wǎng)站等業(yè)務。立足成都服務烏達,10余年網(wǎng)站建設經驗,價格優(yōu)惠、服務專業(yè),歡迎來電咨詢建站服務:18980820575
J2EE平臺由一整套服務(Services)、應用程序接口(APIs)和協(xié)議構成,它對開發(fā)基于Web的多層應用提供了功能支持。在本文中將解釋支撐J2EE的13種核心技術:JDBC,JNDI,EJBs,RMI,JSP,Javaservlets,XML,JMS,JavaIDL,JTS,JTA,JavaMail和JAF,同時還將描述在何時、何處需要使用這些技術。當然,我還要介紹這些不同的技術之間是如何交互的。此外,為了讓您更好地感受J2EE的真實應用,將在WebLogic應用服務器,來自BEA Systems公司的一種廣為應用的產品環(huán)境下來介紹這些技術。不論對于Web Logic應用服務器和J2EE的新手,還是那些想了解J2EE能帶來什么好處的項目管理者和系統(tǒng)分析員,相信本文一定很有參考價值。
宏觀印象:分布式結構和J2EE
過去,二層化應用--通常被稱為client/server應用--是大家談論的最多的。在很多情況下,服務器提供的惟一服務就是數(shù)據(jù)庫服務。在這種解決方案中,客戶端程序負責數(shù)據(jù)訪問、實現(xiàn)業(yè)務邏輯、用合適的樣式顯示結果、彈出預設的用戶界面、接受用戶輸入等。client/server結構通常在第一次部署的時候比較容易,但難于升級或改進,而且經?;谀撤N專有的協(xié)議,通常是某種數(shù)據(jù)庫協(xié)議。它使得重用業(yè)務邏輯和界面邏輯非常困難。更重要的是,在Web時代,二層化應用通常不能體現(xiàn)出很好的伸縮性,因而很難適應Internet的要求。
Sun設計J2EE的部分起因就是想解決二層化結構的缺陷。于是,J2EE定義了一套標準來簡化N層企業(yè)級應用的開發(fā)。它定義了一套標準化的組件,并為這些組件提供了完整的服務。J2EE還自動為應用程序處理了很多實現(xiàn)細節(jié),如安全、多線程等。
用J2EE開發(fā)N層應用包括將二層化結構中的不同層面切分成許多層。一個N層化應用A能夠為以下的每種服務提供一個分開的層:
顯示:在一個典型的Web應用中,客戶端機器上運行的瀏覽器負責實現(xiàn)用戶界面。
動態(tài)生成顯示:盡管瀏覽器可以完成某些動態(tài)內容顯示,但為了兼容不同的瀏覽器,這些動態(tài)生成工作應該放在Web服務器端進行,使用JSP、Servlets,或者XML(可擴展標記語言)和(可擴展樣式表語言)。
業(yè)務邏輯:業(yè)務邏輯適合用SessionEJBs(后面將介紹)來實現(xiàn)。
數(shù)據(jù)訪問:數(shù)據(jù)訪問適合用EntityEJBs(后面將介紹)和JDBC來實現(xiàn)。
后臺系統(tǒng)集成:同后臺系統(tǒng)的集成可能需要用到許多不同的技術,至于何種最佳需要根據(jù)后臺系統(tǒng)的特征而定。
您可能開始詫異:為什么有這么多的層?事實上,多層方式可以使企業(yè)級應用具有很強的伸縮性,它允許每層專注于特定的角色。例如,讓Web服務器負責提供頁面,應用服務器處理應用邏輯,而數(shù)據(jù)庫服務器提供數(shù)據(jù)庫服務。
由于J2EE建立在Java2平臺標準版(J2SE)的基礎上,所以具備了J2SE的所有優(yōu)點和功能。包括“編寫一次,到處可用”的可移植性、通過JDBC訪問數(shù)據(jù)庫、同原有企業(yè)資源進行交互的CORBA技術,以及一個經過驗證的安全模型。在這些基礎上,J2EE又增加了對EJB(企業(yè)級Java組件)、Javaservlets、Java服務器頁面(JSPs)和XML技術的支持。
分布式結構與WebLogic應用服務器
J2EE提供了一個框架--一套標準API--用于開發(fā)分布式結構的應用,這個框架的實際實現(xiàn)留給了第三方廠商。部分廠商只是專注于整個J2EE架構中的的特定組件,例如Apache的Tomcat提供了對JSP和servlets的支持,BEA系統(tǒng)公司則通過其WebLogic應用服務器產品為整個J2EE規(guī)范提供了一個較為完整的實現(xiàn)。
WebLogic服務器已使建立和部署伸縮性較好的分布式應用的過程大為簡化。WebLogic和J2EE代你處理了大量常規(guī)的編程任務,包括提供事務服務、安全領域、可靠的消息、名字和目錄服務、數(shù)據(jù)庫訪問和連接池、線程池、負載平衡和容錯處理等。
通過以一種標準、易用的方式提供這些公共服務,象WebLogic服務器這樣的產品造就了具有更好伸縮性和可維護性的應用系統(tǒng),使其為大量的用戶提供了增長的可用性。
J2EE技術
在接下來的部分里,我們將描述構成J2EE的各種技術,并且了解WebLogic服務器是如何在一個分布式應用中對它們進行支持的。最常用的J2EE技術應該是JDBC、JNDI、EJB、JSP和servlets,對這些我們將作更仔細的考察。
Java Database Connectivity(JDBC)
JDBCAPI以一種統(tǒng)一的方式來對各種各樣的數(shù)據(jù)庫進行存取。和ODBC一樣,JDBC為開發(fā)人員隱藏了不同數(shù)據(jù)庫的不同特性。另外,由于JDBC建立在Java的基礎上,因此還提供了數(shù)據(jù)庫存取的平臺獨立性。
JDBC定義了4種不同的驅動程序,現(xiàn)分述如下:
類型1:JDBC-ODBCBridge
在JDBC出現(xiàn)的初期,JDBC-ODBC橋顯然是非常有實用意義的,通過JDBC-ODBC橋,開發(fā)人員可以使用JDBC來存取ODBC數(shù)據(jù)源。不足的是,他需要在客戶端安裝ODBC驅動程序,換句話說,必須安裝MicrosoftWindows的某個版本。使用這一類型你需要犧牲JDBC的平臺獨立性。另外,ODBC驅動程序還需要具有客戶端的控制權限。
類型2:JDBC-nativedriverbridge
JDBC本地驅動程序橋提供了一種JDBC接口,它建立在本地數(shù)據(jù)庫驅動程序的頂層,而不需要使用ODBC。JDBC驅動程序將對數(shù)據(jù)庫的API從標準的JDBC調用轉換為本地調用。使用此類型需要犧牲JDBC的平臺獨立性,還要求在客戶端安裝一些本地代碼。
類型3:JDBC-networkbridge
JDBC網(wǎng)絡橋驅動程序不再需要客戶端數(shù)據(jù)庫驅動程序。它使用網(wǎng)絡上的中間服務器來存取數(shù)據(jù)庫。這種應用使得以下技術的實現(xiàn)有了可能,這些技術包括負載均衡、連接緩沖池和數(shù)據(jù)緩存等。由于第3種類型往往只需要相對更少的下載時間,具有平臺獨立性,而且不需要在客戶端安裝并取得控制權,所以很適合于Internet上的應用。
類型4:PureJavadriver
第4種類型通過使用一個純Java數(shù)據(jù)庫驅動程序來執(zhí)行數(shù)據(jù)庫的直接訪問。此類型實際上在客戶端實現(xiàn)了2層結構。要在N-層結構中應用,一個更好的做法是編寫一個EJB,讓它包含存取代碼并提供一個對客戶端具有數(shù)據(jù)庫獨立性的服務。
WebLogic服務器為一些通常的數(shù)據(jù)庫提供了JDBC驅動程序,包括Oracle,Sybase,MicrosoftSQLServer以及Informix。它也帶有一種JDBC驅動程序用于Cloudscape,這是一種純Java的DBMS,WebLogic服務器中帶有該數(shù)據(jù)庫的評估版本。
以下讓我們看一個JDBC實例:在這個例子中我們假定你已經在Cloudscape中建立了一個PhoneBook數(shù)據(jù)庫,并且包含一個表,名為CONTACT_TABLE,它帶有2個字段:NAME和PHONE。開始的時候先裝載CloudscapeJDBCdriver,并請求drivermanager得到一個對PhoneBookCloudscape數(shù)據(jù)庫的連接。通過這一連接,我們可以構造一個Statement對象并用它來執(zhí)行一個簡單的SQL查詢。最后,用循環(huán)來遍歷結果集的所有數(shù)據(jù),并用標準輸出將NAME和PHONE字段的內容進行輸出。
import java.sql.*; |
OK。接著來看一看JDBC是如何在企業(yè)應用中的進行使用。