自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

在JSP程序中Application使用淺析

開(kāi)發(fā) 后端
本文向您介紹JSP程序中Application Session Page的設(shè)置,通過(guò)分析和實(shí)例代碼詳解講解Application的特性。

JSP程序調(diào)用Javeabean命令UseBean中有Scope設(shè)置,一般有Application session page等設(shè)置,Page就是每頁(yè)重新產(chǎn)生usebean中的javabean新對(duì)象,一般情況是用這種,如果多個(gè)JSP程序間為共享數(shù)據(jù),可以使用session

而Application的意思,該javabean將一直存在,與session相對(duì)用戶來(lái)說(shuō),Application是相對(duì)應(yīng)用程序的,一般來(lái)說(shuō),一個(gè)用戶有一個(gè)session,并且隨著用戶離開(kāi)而消失;而Application則是一直存在,類似一個(gè)servlet程序,類似整個(gè)系統(tǒng)的"全局變量",而且只有一個(gè)實(shí)例。

MVC中控制功能

因此application這個(gè)特性,很適合用來(lái)做MVC中的控制功能,一般傳統(tǒng)MVC是用servlet做控制功能,V基本是JSP頁(yè)面,M就是中間件Javabean之類。

但是隨著JSP功能的完善和推廣,逐漸有替代servlet之趨勢(shì),我們?cè)趯?shí)踐中更多使用的也是JSP,有時(shí)為了省卻麻煩的事情,就使用JSP代替servlet.尤其是其控制功能。

實(shí)際上,這個(gè)控制功能是封裝在一個(gè)Javabean中,JSP程序使用scope=application來(lái)調(diào)用這個(gè)Javabean,這樣,具備控制功能的javabean就類似servlet常駐內(nèi)存,并和后臺(tái)各種中間件交互操作。

“首頁(yè)”的展現(xiàn)

在實(shí)際應(yīng)用中,我們經(jīng)常有多個(gè)用戶要同時(shí)訪問(wèn)一個(gè)頁(yè)面,如首頁(yè),這個(gè)首頁(yè)中有很多功能要運(yùn)行,比如目錄分類,首頁(yè)程序要從數(shù)據(jù)庫(kù)中讀入樹(shù)形數(shù)據(jù)并展開(kāi),輸出到首頁(yè),這個(gè)功能是封裝在Javabean中的。

那么首頁(yè)JSP程序調(diào)用這個(gè)Javabean時(shí),使用scope=application, 再通過(guò)樹(shù)形數(shù)據(jù)的緩沖算法,這樣,多個(gè)用戶同時(shí)訪問(wèn)首頁(yè)時(shí),首頁(yè)JSP程序就無(wú)需每次啟動(dòng)Javabean然后再反復(fù)讀取數(shù)據(jù)庫(kù)了。無(wú)疑大大提高速度。

所以如果你的首頁(yè)JSP訪問(wèn)量很高,那么就應(yīng)該在這方面多花點(diǎn)時(shí)間優(yōu)化。

數(shù)據(jù)庫(kù)連接緩沖

  1. <jsp:useBean id="cods" 
  2.   class="oracle.jdbc.pool.OracleConnectionCacheImpl"   
  3.   scope="application" /> 
  4.  
  5.  
  6. <event:application_OnStart> 
  7. <%   
  8. cods.setURL("jdbc:oracle:thin:@HOST:PORT:SID");  
  9. cods.setUser("scott");  
  10. cods.setPassword("tiger");  
  11. cods.setStmtCache (5);   
  12. %> 
  13. </event:application_OnStart> 
  14.  
  15.  
  16. <%@ page import="java.sql.*, javax.sql.*, oracle.jdbc.pool.*" %> 
  17.  
  18. <!----------------------------------------------------------------  
  19. * This is a JavaServer Page that uses Connection Caching over  
  20. application  
  21. * scope. The Cache is created in an application scope in  
  22. globals.jsa file.   
  23. * Connection is obtained from the Cache and recycled back once  
  24. done.  
  25.  
  26. --------------------------------------------------------------------!> 
  27.  
  28. <HTML>   
  29. <HEAD>   
  30. <TITLE> 
  31. ConnCache JSP  
  32. </TITLE> 
  33. </HEAD> 
  34. <BODY BGCOLOR=EOFFFO>   
  35. <H1> Hello   
  36. <%= (request.getRemoteUser() != null? ", " +  
  37. request.getRemoteUser() : "") %> 
  38. ! I am Connection Caching JSP.  
  39. </H1> 
  40. <HR> 
  41. <B> I get the Connection from the Cache and recycle it back.  
  42. </B>   
  43.  
  44. <P> 
  45. <%  
  46. try {  
  47. Connection conn = cods.getConnection();  
  48.  
  49. Statement stmt = conn.createStatement ();  
  50. ResultSet rset = stmt.executeQuery ("SELECT ename, sal " +   
  51. "FROM scott.emp ORDER BY ename");  
  52.  
  53. if (rset.next()) {  
  54. %> 
  55. <TABLE BORDER=1 BGCOLOR="C0C0C0"> 
  56. <TH WIDTH=200 BGCOLOR="white"> <I>Employee Name</I> </TH> 
  57. <TH WIDTH=100 BGCOLOR="white"> <I>Salary</I> </TH> 
  58. <TR> <TD ALIGN=CENTER> <%= rset.getString(1) %> </TD> 
  59. <TD ALIGN=CENTER> $<%= rset.getDouble(2) %> </TD> 
  60. </TR> 
  61.  
  62. <% while (rset.next()) {  
  63. %> 
  64.  
  65. <TR> <TD ALIGN=CENTER> <%= rset.getString(1) %> </TD> 
  66. <TD ALIGN=CENTER> $<%= rset.getDouble(2) %> </TD> 
  67. </TR> 
  68.  
  69. <% }  
  70. %> 
  71. </TABLE> 
  72. <% }   
  73. else {  
  74. %> 
  75. <P> Sorry, the query returned no rows! </P> 
  76.  
  77. <%   
  78. }  
  79. rset.close();  
  80. stmt.close();  
  81. conn.close(); // Put the Connection Back into the Pool  
  82.  
  83. } catch (SQLException e) {  
  84. out.println("<P>" + "There was an error doing the query:");  
  85. out.println ("<PRE>" + e + "</PRE> \n <P>");  
  86. }  
  87. %> 
  88.  
  89. </BODY> 
  90. </HTML> 

在JSP程序的實(shí)際運(yùn)行中,使用Application緩存數(shù)據(jù)庫(kù)的連接,每次使用時(shí),從緩沖中取出,用完就返回。

 

【編輯推薦】

  1. 教你在JSP中使用JavaMail
  2. 在JSP中動(dòng)態(tài)生成并調(diào)用JSP程序
  3. JSTL介紹—JSP編程新組件 允許用標(biāo)簽編程
  4. JSP開(kāi)發(fā)所需要的Eclipse插件及安裝配置方法
  5. JDBC與JSP簡(jiǎn)單模擬MVC三層架構(gòu)
責(zé)任編輯:佚名 來(lái)源: jdon.com
相關(guān)推薦

2009-06-29 17:57:30

ApplicationJSP

2009-06-10 17:03:36

JSP動(dòng)態(tài)生成

2009-07-02 11:34:42

JSP指令JSP開(kāi)發(fā)

2009-03-17 16:18:51

JspActionStruts

2009-07-02 10:51:21

腳本編程JSP開(kāi)發(fā)

2009-06-29 17:39:31

JSP設(shè)計(jì)模式

2009-07-06 13:52:56

編寫JSP Tag

2017-05-24 09:43:42

2009-06-30 10:59:38

fckeditorJSP

2009-07-06 14:05:11

JSP服務(wù)器

2009-07-03 09:08:23

JSP標(biāo)記學(xué)習(xí)筆記

2009-07-03 09:08:23

JSP標(biāo)記學(xué)習(xí)筆記

2021-03-06 14:22:39

池化對(duì)象類庫(kù)

2009-07-14 10:47:47

MyEclipse J

2011-08-29 17:27:47

HTML 5交互移動(dòng)應(yīng)用

2009-06-16 09:06:37

JavaMailJSP

2009-03-02 09:45:45

2009-07-02 09:25:41

JSP實(shí)現(xiàn)頁(yè)面跳轉(zhuǎn)

2009-07-01 18:20:29

JSP的優(yōu)勢(shì)

2009-09-28 13:23:54

HTTP編程
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)