JSP與servlet的區別

JSP中調用JAVA類和使用JavaBean有什麼區別?

可以像使用一般的類一樣使用JavaBean,Bean只是一種特殊的類。特殊在可以通過<jsp:useBean   />調用JavaBean而其他類,可以和一般java中一樣使用.  Bean的參數中還可以指定範圍, <jsp:useBean  scope="application"   />Bean在服務器的JVM中將只有一個實例. Bean是和WebServer相關的,不同的頁面可以通過Bean 交互.而在一個頁面中的類,就沒有這個功能,除非通過session,那又是另外一回事了. 

 bean其時也是class文件,只是普通的java文件沒有什麼限制,如果按bean的規範來製作class文件,那他就是一個bean。而按bean的規範來製作就相當是一個組件,換句話說bean就是組件技術。

爲了確保一個java類成爲javabean,有以下四個簡單的也是必須的規範: 

n         這個類是可序列化的,即必須實現java.io.Serializable接口。 

n         這個類必須帶有一個無參數的構造方法。 

n         若成員變量名爲XXX,那麼要有方法getXXX(),用來獲取屬性;setXXX(),用來修改屬性;對於Boolean類型的成員變量,可用is代替getset類中的方法的訪問。屬性都必須是public的。類中如果有構造方法,那麼這個構造方法也是public的,並且無參數。 

n         這個類包含所有必需的事件處理方法。 

JavaBeanServlet的不同 

Type1: 一般的JavaBean中,只有屬性聲明和該屬性對應的setXxxgetXxx方法,(一般不建議)不包含業務邏輯;這種JavaBean可以簡單地理解爲“數據對象”即可。

Type2: 還有一種JavaBean,其內包含業務處理邏輯,用於處理特定的業務數據;一般使用上面所述的“數據對象”(當然也可能不使用)。
    Servlet
主要是用來:接收請求、封裝‘Type1’JavaBean、調用‘Type2’JavaBean的相應業務邏輯方法、向客戶端發出響應。

以上是Struts 1.x所使用的模式:ActionForm 就是 Type1JavaBeanActionBean就是Type2JavaBeanActionServlet即是上面所述的Servlet Struts 2.x則是使用 Type1 + Type2的方式(數據對象和業務處理)和Servlet相結合的方式(實際上就是Webwork的方式)。 


javaBeanServlet有什麼區別?

什麼時候用javaBaen?

什麼時候用Servlet,什麼時候二者結合使用?

n         javabean無非就是裏面有些setget方法

n         servlet用來處理一些邏輯層 

n         javabean說籠統點是實現

n         javabeanservletjsp分別對應Model)、Controller)、View 

舉例: servlet查詢數據庫-----javabean保存查詢結果-----jsp顯示查詢結果 

javabean就是一個普通的Java類,裏面爲屬性增加了gettersetter並提供默認構造。可以在多層架構的各層存在。想用它作什麼都行。 

Servlet是展示層的東西……應當只在展示層存在。常作爲MVC中的控制器。 
一般說的Mvc模式,Servlet主要充當了C的作用。

javabeanservlet是兩回事.因爲javabean是一個組件,可以用在任何地方,當然就可以用在servlet裏了 
   
 按照Sun的定義,所謂的JavaEE應用,是由兩大部分組成:(1)組件,表示業務邏輯、表現邏輯,這部分由開發人員完成;(2)標準的系統服務,由JavaEE平臺,亦即容器來提供,這個範圍之外的都不屬於JavaEE應用的範疇。而Servlet,作爲JavaEE應用表現邏輯的組件之一,當然是JavaEE應用的一部分。而JavaBean,產生的年代早於J2EE,其技術用途更爲廣泛不限於JavaEE使用,按照sun的定義,不屬於JavaEE技術範圍。

其實真正大規模使用JavaBean組件技術的是在Swing中,wing中的所有控件包括JButtonJTree等用的都是JavanBean技術,這些控件的基本編程模型正是大名鼎鼎的MVC模型,不信找出Swing API來,好好研究一下JTreeJTable,就知道什麼是真正的JavaBean了。

Servlet是只能在JavaEE容器中存活的特殊Java類,就像是魚缸裏的魚,沒有容器Servlet是不能生存的。而JavaBean則可以脫離JavaEE環境單獨存在,按照Sun的說法,既可以用在客戶端,也可以用在服務器端。

所謂的POJO,就是EJBE字去掉,剩下的JB就是JavaBean,換句話說,JavaBeanJ2EE裏,甚至可以充當某些EJB完成的任務,用途遠大於Servlet。最後的區別,就是 JavaBean的主要用途在於管理JavaEE應用各個層之間的數據流,所以在一些框架中(如Struts)有FormBeanActionBean的說法,其本質都是爲了管理數據。相信如果把上述幾點搞清,區分ServletJavaBean應當不會很困難的。 

JSPServlet到底在應用上有什麼區別?

簡單的說,SUN首先發展出Servlet,其功能比較強勁,體系設計也很先進,只是,它輸出HTML語句還是採用了老的CGI方式,是一句一句輸出,所以,編寫和修改HTML非常不方便。 後來SUN推出了類似於ASP的鑲嵌型的JSP,把JSP TAG鑲嵌到HTML語句中,這樣,就大大簡化和方便了網頁的設計和修改。

新型的網絡語言如ASPPHPJSP都是鑲嵌型的SCRIPT語言。 從網絡三層結構的角度看,一個網絡項目最少分三層:data layer,business layer, presentation layer。當然也可以更復雜。

Servlet用來寫business layer是很強大的,但是對於寫presentation layer就很不方便。JSP則主要是爲了方便寫presentation layer而設計的。當然也可以寫business layer

寫慣了ASPPHPCGI的朋友,經常會不自覺的把presentation layerbusiness layer混在一起,就像把數據庫處理信息放到JSP中。其實,它應該放在business layer中。根據SUN自己的推薦,JSP中應該僅僅存放與presentation layer有關的東西,也就是說,只放輸出HTML網頁的部份。而所有的數據計算,數據分析,數據庫聯結處理,統統是屬於business layer,應該放在JavaBean中。通過JSP調用JavaBean,實現兩層的整合。

實際上,微軟前不久推出的DNA技術,簡單說,就是ASP+COM/DCOM技術。與JSP+BEANS完全類似,所有的presentation layerASP完成,所有的business layerCOM/DCOM完成。通過調用,實現整合。

爲什麼要採用這些組件技術呢?因爲單純的ASP/JSP語言是非常低效率執行的,如果出現大量用戶點擊,純SCRIPT語言很快就到達了他的功能上限,而組件技術就能大幅度提高功能上限,加快執行速度。 
  另外一方面,純SCRIPT語言將presentation layerbusiness layer混在一起,造成修改不方便,並且代碼不能重複利用。如果想修改一個地方,經常會牽涉到十幾頁CODE,採用組件技術就只改組件就可以了 
  綜上所述,Servlet是一個早期的不完善的產品,寫business layer很好,寫presentation layer就很臭,並且兩層混雜。 
  所以,推出JSP+Bean,用JSPpresentation layer,Beanbusiness layerSUN自己的意思也是將來用JSP替代Servlet 
  可是,這不是說,學了Servlet沒用,實際上,還是應該從Servlet入門,再上JSP,再上JSP+BEAN 
  強調的是:學了JSP,不會用JavaBean並進行整合,等於沒學。大家多花點力氣在JSP+Bean上。 

我們可以看到,當ASP+COMJSP+Bean都採用組件技術後,所有的組件都是先進行編譯,並駐留內存,然後快速執行。所以,大家經常吹的Servlet/JSP先編譯駐內存後執行的速度優勢就沒有了。 
  反之,ASP+COM+IIS+NT緊密整合,應該會有較大的速度優勢呈現。而且,ASP+COM+IIS+NT開發效率非常高,雖然BUG很多。 
  那麼,爲什麼還用JSP+Bean

因爲JAVA實在前途遠大。微軟分拆後,操作系統將羣雄並起,應用軟件的開發商必定要找一個通用開發語言進行開發,JAVA一統天下的時機就到了。如果微軟分拆順利,從中分出的應用軟件公司將成爲JAVA的新領導者。

目前的JAVA大頭SUNIBM都死氣沉沉,令人失望。希望新公司能注入新活力。不過,新公司很有可能和舊SUN展開JAVA標準大戰,雙方各自制定標準,影響JAVA誇平臺。 
  另外,現在的機器速度越來越快,JAVA的速度劣勢很快就可以被克服。javabean可以作爲模型+控制,也可以單做模型,也可以只用來做數據傳遞(JSP發送數據到BeanBeanN執行execute,操作數據庫,反之也可) 
   
 如果還沒學到其它框架,如HIBERNATE,SPRING,STRUTS等。那javabean的作用是用來作數據的裝載,這種bean我稱爲數據bean,比如從數據庫上查詢出的記錄可以保存在數據bean中。

javabean的另一外作用是用來處理一些業務邏輯,比如可以在javabean中用JDBC去訪問數據庫,從而從數據庫中加載信息到數據bean中,也可以從數據庫中刪除、保存數據等。

Servlet的作用主要是用來控制頁面的跳轉,比如說從login.jsp發一個請求到Servlet中,Servlet調用業務bean的方法去查詢數據庫是否有此密碼和用戶名,如果正確Servlet就可以用request或者response對象的方法跳轉到想要的頁面。 


JSP開發的兩種模式

模式一:JSP+JavaBeans 

這就是指JSP+JavaBean技術。在模式一中,JSP頁面獨自響應請求並將處理結果返回客戶。所有的數據通過Bean來處理JSP實現頁面的表現。模式一技術也實現了頁面的表現--和頁面的商業邏輯相分離。
  大量使用模式形式,常常會導致頁面被嵌入大量的腳本語言或JAVA代碼。當需要處理的商業邏輯很複雜時,這種情況會變得非常糟糕。大量的代碼會使整個頁面變得非常複雜。對於前端界面設計人員來說,這簡直不可想象。
  這種情況在大項目中最爲常見,這也造成了代碼的開發和維護出現困難,造成了不必要的資源浪費,在任何項目中,這樣的模式總會導致多多少少的定義不清的響應和項目管理的困難。
  綜上所訴,模式一不能滿足大型項目的需要,但是可以較好的滿足小型應用,在簡單的應用中可以考慮模式一。 

 

模式二:JSP+Servlet+JavaBeans

Servlets技術是一種採用JAVA技術來實現CGI功能的一種術。Servlets技術是運行在WEB服務器上,用來生成WEB頁面。Servlets技術非常適用於服務器端的處理和編程,並且Servlet會長期駐留在他們所處的位置。   
    但是在實際的項目開發過程中,頁面設計者可以方便地使用普通HTML工具來開發JSP頁面Servlet卻更適合於後端開發者使用,開發Servlet需要的是JAVA集成開發環境,也就是說Servlet技術更需要編程人員。    
    模式二技術結合了JSPServlet技術充分體現了兩者的技術優點。在此模式中通過JSP來表現頁面。通過Servlet來完成大量的事務處理。Servlet充當一個控制者的角色,並負責向客戶發送請求。Servlet創建JSP所需要的Bean和對象,然後根據用戶的請求行爲,決定將哪個JSP頁面發送給客戶。    
    從開發的觀點,模式二具有更清晰的頁面表現,清楚的開發者角色劃分,可以充分利用開發小組的界面設計人員,這些優勢在大型項目開發中表現的尤爲突出,使用這一模式,可以充分發揮每個開發者各自的特長,界面設計人員可以充分發揮自己的表現力,設計出優美的界面表現形式,設計人員可以充分發揮自己的商務處理思維,來實現項目中的業務處理。在大型項目中,模式二更被採用。 

    
   Servlet是一種獨立於平臺和協議的位於Web服務器內部的服務器端的Java應用程序,與傳統的從命令行啓動的Java應用程序不同,ServletWeb服務器進行加載,該Web服務器必須包含支持ServletJava虛擬機。  

JavaServletJSP(JavaServerPages)的比較:

JavaServerPages(JSP)是一種實現普通靜態HTML和動態HTML混合編碼的技術,JSP並沒有增加任何本質上不能用Servlet實現的功能。但是,在 JSP中編寫靜態HTML更加方便,不必再用println語句來輸出每一行HTML代碼。更重要的是,藉助內容和外觀的分離,頁面製作中不同性質的任務可以方便地分開:比如,由頁面設計者進行HTML設計,同時留出供Servlet程序員插入動態內容的空間。  
   JSP動態Web內容可能是動態Web內容的一項偉大的技術,並可將內容和表示presentation相分離,那爲什麼servlets仍然有必要和JSP同時實施?    
  其實servlets的實用性並不是一個問題。它們在服務器端處理方面的表現非常優秀,而且,由於它們引人注目的安裝方式而繼續存在着。事實上,可以將 JSP看作一種servlets的高級抽象,它以Servlet2.1API擴展的形式來實現。

注意:不應該不加選擇地使用servlets;它們可能並不適用於每個人。例如,當一個頁面設計者可以很簡單地使用方便的HTMLXML工具來編寫 JSP頁面時,servlets可能更適合那些在後端的開發者,因爲他們經常使用某種IDE來編寫。這是一種通常需要較高編程經驗的處理工作。

當發佈servlets時,甚至開發者都不得不小心確保在presentation和內容之間不存在緊密結合。通常可以通過增加一個第三方發行包如 htmlKona來做到這一點。但即使可以做到這一點,雖然可以通過簡單的屏幕上的調整提供一些靈活性,仍無法保證在presentation自身格式上的變化。例如,如果你的presentationHTML改變到DHTML,將仍然需要確保發行包和新的格式相一致,在最壞的case--scenario中,如果一個發行包無法得到,你將結束在動態web的內容中對presentation使用手寫代碼。所以,解決方法是什麼呢?

方法之一就是同時使用JSPservlet技術來建立應用系統。

發佈了13 篇原創文章 · 獲贊 8 · 訪問量 4萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章