国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學(xué)院 > 開發(fā)設(shè)計(jì) > 正文

J2EE的13種核心技術(shù)

2019-11-18 12:27:25
字體:
供稿:網(wǎng)友

  java最初是在瀏覽器和客戶端機(jī)器中粉墨登場的。當(dāng)時(shí),很多人質(zhì)疑它是否適合做服務(wù)器端的開發(fā)。現(xiàn)在,隨著對Java2平臺企業(yè)版(J2EE)第三方支持的增多,Java被廣泛接納為開發(fā)企業(yè)級服務(wù)器端解決方案的首選平臺之一。
  
  J2EE平臺由一整套服務(wù)(Services)、應(yīng)用程序接口(APIs)和協(xié)議構(gòu)成,它對開發(fā)基于Web的多層應(yīng)用提供了功能支持。
  
  在本文中我將解釋支撐J2EE的13種核心技術(shù):JDBC, JNDI, EJBs, RMI, jsp, Java servlets, xml, JMS, Java IDL, JTS, JTA, JavaMail 和 JAF,同時(shí)還將描述在何時(shí)、何處需要使用這些技術(shù)。當(dāng)然,我還要介紹這些不同的技術(shù)之間是如何交互的。
  
  此外,為了讓您更好地感受J2EE的真實(shí)應(yīng)用,我將在WebLogic應(yīng)用服務(wù)器―來自BEA Systems公司的一種廣為應(yīng)用的產(chǎn)品―環(huán)境下來介紹這些技術(shù)。不論對于WebLogic應(yīng)用服務(wù)器和J2EE的新手,還是那些想了解J2EE能帶來什么好處的項(xiàng)目治理者和系統(tǒng)分析員,相信本文一定很有參考價(jià)值。
  
  宏觀印象: 分布式結(jié)構(gòu)和J2EE
  過去,二層化應(yīng)用 -- 通常被稱為client/server應(yīng)用 -- 是大家談?wù)摰淖疃嗟摹D1刻畫了典型的二層化結(jié)構(gòu)。在很多情況下,服務(wù)器提供的唯一服務(wù)就是數(shù)據(jù)庫服務(wù)。在這種解決方案中,客戶端程序負(fù)責(zé)數(shù)據(jù)訪問、實(shí)現(xiàn)業(yè)務(wù)邏輯、用合適的樣式顯示結(jié)果、彈出預(yù)設(shè)的用戶界面、接受用戶輸入等。client/server結(jié)構(gòu)通常在第一次部署的時(shí)候比較輕易,但難于升級或改進(jìn),而且經(jīng)常基于某種專有的協(xié)議―通常是某種數(shù)據(jù)庫協(xié)議。它使得重用業(yè)務(wù)邏輯和界面邏輯非常困難。更重要的是,在Web時(shí)代,二層化應(yīng)用通常不能體現(xiàn)出很好的伸縮性,因而很難適應(yīng)Internet的要求。
  
  Sun設(shè)計(jì)J2EE的部分起因就是想解決二層化結(jié)構(gòu)的缺陷。于是,J2EE定義了一套標(biāo)準(zhǔn)來簡化N層企業(yè)級應(yīng)用的開發(fā)。它定義了一套標(biāo)準(zhǔn)化的組件,并為這些組件提供了完整的服務(wù)。J2EE還自動為應(yīng)用程序處理了很多實(shí)現(xiàn)細(xì)節(jié),如安全、多線程等。
  
  用J2EE開發(fā)N層應(yīng)用包括將二層化結(jié)構(gòu)中的不同層面切分成許多層。一個N層化應(yīng)用A能夠?yàn)橐韵碌拿糠N服務(wù)提供一個分開的層:
  
  顯示:在一個典型的Web應(yīng)用中,客戶端機(jī)器上運(yùn)行的瀏覽器負(fù)責(zé)實(shí)現(xiàn)用戶界面。
  
  動態(tài)生成顯示: 盡管瀏覽器可以完成某些動態(tài)內(nèi)容顯示,但為了兼容不同的瀏覽器,這些動態(tài)生成工作應(yīng)該放在Web服務(wù)器端進(jìn)行,使用JSP、Servlets,或者XML(可擴(kuò)展標(biāo)記語言)和(可擴(kuò)展樣式表語言)。
  業(yè)務(wù)邏輯:業(yè)務(wù)邏輯適合用session EJBs(后面將介紹)來實(shí)現(xiàn)。
  
  數(shù)據(jù)訪問:數(shù)據(jù)訪問適合用Entity EJBs(后面將介紹)和JDBC來實(shí)現(xiàn)。
  
  后臺系統(tǒng)集成: 同后臺系統(tǒng)的集成可能需要用到許多不同的技術(shù),至于何種最佳需要根據(jù)后臺系統(tǒng)的特征而定。
  
  您可能開始詫異:為什么有這么多的層?事實(shí)上,多層方式可以使企業(yè)級應(yīng)用具有很強(qiáng)的伸縮性,它答應(yīng)每層專注于特定的角色。例如,讓W(xué)eb服務(wù)器負(fù)責(zé)提供頁面,應(yīng)用服務(wù)器處理應(yīng)用邏輯,而數(shù)據(jù)庫服務(wù)器提供數(shù)據(jù)庫服務(wù)。
  
  由于J2EE建立在Java2平臺標(biāo)準(zhǔn)版(J2SE)的基礎(chǔ)上,所以具備了J2SE的所有優(yōu)點(diǎn)和功能。包括“編寫一次,到處可用”的可移植性、通過JDBC訪問數(shù)據(jù)庫、同原有企業(yè)資源進(jìn)行交互的CORBA技術(shù),以及一個經(jīng)過驗(yàn)證的安全模型。在這些基礎(chǔ)上,J2EE又增加了對EJB(企業(yè)級Java組件)、Java servlets、Java服務(wù)器頁面(JSPs)和XML技術(shù)的支持。
  
  分布式結(jié)構(gòu)與WebLogic應(yīng)用服務(wù)器
  J2EE提供了一個框架--一套標(biāo)準(zhǔn)API--用于開發(fā)分布式結(jié)構(gòu)的應(yīng)用,這個框架的實(shí)際實(shí)現(xiàn)留給了第三方廠商。部分廠商只是專注于整個J2EE架構(gòu)中的的特定組件,例如Apache的Tomcat提供了對JSP和servlets的支持,BEA系統(tǒng)公司則通過其WebLogic應(yīng)用服務(wù)器產(chǎn)品為整個J2EE規(guī)范提供了一個較為完整的實(shí)現(xiàn)。
  
  WebLogic服務(wù)器已使建立和部署伸縮性較好的分布式應(yīng)用的過程大為簡化。WebLogic和J2EE代你處理了大量常規(guī)的編程任務(wù),包括提供事務(wù)服務(wù)、安全領(lǐng)域、可靠的消息、名字和目錄服務(wù)、數(shù)據(jù)庫訪問和連接池、線程池、負(fù)載平衡和容錯處理等。
  
  通過以一種標(biāo)準(zhǔn)、易用的方式提供這些公共服務(wù),象WebLogic服務(wù)器這樣的產(chǎn)品造就了具有更好伸縮性和可維護(hù)性的應(yīng)用系統(tǒng),使其為大量的用戶提供了增長的可用性。
  
  J2EE技術(shù)
  在接下來的部分里,我們將描述構(gòu)成J2EE的各種技術(shù),并且了解WebLogic服務(wù)器是如何在一個分布式應(yīng)用中對它們進(jìn)行支持的。最常用的J2EE技術(shù)應(yīng)該是JDBC、JNDI、EJB、JSP和servlets,對這些我們將作更仔細(xì)的考察。
  
  Java Database Connectivity (JDBC)
  
  JDBC API以一種統(tǒng)一的方式來對各種各樣的數(shù)據(jù)庫進(jìn)行存取。和ODBC一樣,JDBC為開發(fā)人員隱藏了不同數(shù)據(jù)庫的不同特性。另外,由于JDBC建立在Java的基礎(chǔ)上,因此還提供了數(shù)據(jù)庫存取的平臺獨(dú)立性。
  
  JDBC定義了4種不同的驅(qū)動程序,現(xiàn)分述如下:
  
  類型 1: JDBC-ODBC Bridge
  
  在JDBC出現(xiàn)的初期,JDBC-ODBC橋顯然是非常有實(shí)用意義的,通過JDBC-ODBC橋,開發(fā)人員可以使用JDBC來存取ODBC數(shù)據(jù)源。不足的是,他需要在客戶端安裝ODBC驅(qū)動程序,換句話說,必須安裝Microsoft Windows的某個版本。使用這一類型你需要犧牲JDBC的平臺獨(dú)立性。另外,ODBC驅(qū)動程序還需要具有客戶端的控制權(quán)限。
  
  類型 2: JDBC-native driver bridge
  
  JDBC本地驅(qū)動程序橋提供了一種JDBC接口,它建立在本地?cái)?shù)據(jù)庫驅(qū)動程序的頂層,而不需要使用ODBC。 JDBC驅(qū)動程序?qū)?shù)據(jù)庫的API從標(biāo)準(zhǔn)的JDBC調(diào)用轉(zhuǎn)換為本地調(diào)用。使用此類型需要犧牲JDBC的平臺獨(dú)立性,還要求在客戶端安裝一些本地代碼。
  
  類型 3: JDBC-network bridge
  
  JDBC網(wǎng)絡(luò)橋驅(qū)動程序不再需要客戶端數(shù)據(jù)庫驅(qū)動程序。它使用網(wǎng)絡(luò)上的中間服務(wù)器來存取數(shù)據(jù)庫。這種應(yīng)用使得以下技術(shù)的實(shí)現(xiàn)有了可能,這些技術(shù)包括負(fù)載均衡、連接緩沖池和數(shù)據(jù)緩存等。由于第3種類型往往只需要相對更少的下載時(shí)間,具有平臺獨(dú)立性,而且不需要在客戶端安裝并取得控制權(quán),所以很適合于Internet上的應(yīng)用。
  
  類型 4: Pure Java driver
  
  第4種類型通過使用一個純Java數(shù)據(jù)庫驅(qū)動程序來執(zhí)行數(shù)據(jù)庫的直接訪問。此類型實(shí)際上在客戶端實(shí)現(xiàn)了2層結(jié)構(gòu)。要在N-層結(jié)構(gòu)中應(yīng)用,一個更好的做法是編寫一個EJB,讓它包含存取代碼并提供一個對客戶端具有數(shù)據(jù)庫獨(dú)立性的服務(wù)。
  
  WebLogic服務(wù)器為一些通常的數(shù)據(jù)庫提供了JDBC驅(qū)動程序,包括Oracle, Sybase, Microsoft SQL Server以及Informix。它也帶有一種JDBC驅(qū)動程序用于Cloudscape,這是一種純Java的DBMS,WebLogic服務(wù)器中帶有該數(shù)據(jù)庫的評估版本。
  以下讓我們看一個實(shí)例。
  
  JDBC實(shí)例
  在這個例子中我們假定你已經(jīng)在Cloudscape中建立了一個PhoneBook數(shù)據(jù)庫,并且包含一個表,名為 CONTACT_TABLE ,它帶有2個字段:NAME 和 PHONE。 開始的時(shí)候先裝載Cloudscape JDBC driver,并請求 driver manager得到一個對PhoneBook Cloudscape數(shù)據(jù)庫的連接。通過這一連接,我們可以構(gòu)造一個 Statement 對象并用它來執(zhí)行一個簡單的SQL查詢。最后,用循環(huán)來遍歷結(jié)果集的所有數(shù)據(jù),并用標(biāo)準(zhǔn)輸出將NAME和PHONE字段的內(nèi)容進(jìn)行輸出。
  
  import java.sql.*;
  
  public class JDBCExample
  {
  public static void main( String args[] )
  {
  try
  {
  Class.forName("COM.cloudscape.core.JDBCDriver");
  Connection conn = DriverManager.getConnection("jdbc:cloudscape:PhoneBook");
  Statement stmt = conn.createStatement();
  String sql = "SELECT name, phone FROM CONTACT_TABLE ORDER BY name";
  ResultSet resultSet = stmt.executeQuery( sql );
  
  String name;
  String phone;
  while ( resultSet.next() )
  {
  name = resultSet.getString(1).trim();
  phone = resultSet.getString(2).trim();
  System.out.PRintln( name + ", " + phone );
  }
  catch ( Exception e )
  {
  // Handle exception here
  e.printStackTrace();
  }
  }
  }
  
  OK。接著我們來看一看JDBC是如何在企業(yè)應(yīng)用中的進(jìn)行使用。
  
  JDBC在企業(yè)級應(yīng)用中的應(yīng)用
  
  以上實(shí)例其實(shí)是很基本的,可能有些微不足道。它假定了一個2層結(jié)構(gòu)。在一個多層的企業(yè)級應(yīng)用中,更大的可能是在客戶端和一個EJB進(jìn)行通信,該EJB將建立數(shù)據(jù)庫連接。為了實(shí)現(xiàn)和改進(jìn)可伸縮性和系統(tǒng)性能, WebLogic服務(wù)器提供了對連接緩沖池connection pool的支持。
  
  Connection pool減少了建立和釋放數(shù)據(jù)庫連接的消耗。在系統(tǒng)啟動以后即可建立這樣的緩沖池,此后如故再有對數(shù)據(jù)庫的請求,WebLogic服務(wù)器可以很簡單地從緩沖池中取出數(shù)據(jù)。數(shù)據(jù)緩沖池可以在WebLogic服務(wù)器的 weblogic.properties 文件中進(jìn)行定義。(可參考 weblogic.properties 文件中的例子,WebLogic服務(wù)器的文檔中還有更具體的參考信息)
  
  在企業(yè)級應(yīng)用的另一個常見的數(shù)據(jù)庫特性是事務(wù)處理。事務(wù)是一組申明statement,它們必須做為同一個statement來處理以保證數(shù)據(jù)完整性。缺省情況下JDBC使用 auto-commit 事務(wù)模式。這可以通過使用Connection類的 setAutoCommit() 方法來實(shí)現(xiàn)。
  
  現(xiàn)在我們已經(jīng)對JDBC有了一些熟悉,下面該轉(zhuǎn)向JNDI了。
  Java Naming and Directory Interface (JNDI)
  
  JNDI API被用于執(zhí)行名字和目錄服務(wù)。它提供了一致的模型來存取和操作企業(yè)

發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 汉沽区| 金山区| 新巴尔虎右旗| 丰台区| 伊通| 栖霞市| 札达县| 龙泉市| 晋江市| 阳泉市| 屏东市| 曲松县| 山阴县| 迭部县| 铜川市| 息烽县| 临颍县| 五家渠市| 锦屏县| 张家川| 五指山市| 衢州市| 纳雍县| 定西市| 麻江县| 晋宁县| 万盛区| 军事| 鸡东县| 桦甸市| 溧阳市| 永仁县| 舒城县| 岳西县| 贺兰县| 南开区| 乌鲁木齐县| 德保县| 邹平县| 中牟县| 突泉县|