转载

在JSP程序中Application使用浅析

JSP程序调用Javeabean命令UseBean中有Scope设置,一般有Application session page等设置,Page就是每页重新产生usebean中的javabean新对象,一般情况是用这种,如果多个JSP程序间为共享数据,可以使用session

而Application的意思,该javabean将一直存在,与session相对用户来说,Application是相对应用程序的,一般来说,一个用户有一个session,并且随着用户离开而消失;而Application则是一直存在,类似一个servlet程序,类似整个系统的"全局变量",而且只有一个实例。

MVC中控制功能

因此application这个特性,很适合用来做MVC中的控制功能,一般传统MVC是用servlet做控制功能,V基本是JSP页面,M就是中间件Javabean之类。

但是随着JSP功能的完善和推广,逐渐有替代servlet之趋势,我们在实践中更多使用的也是JSP,有时为了省却麻烦的事情,就使用JSP代替servlet.尤其是其控制功能。

实际上,这个控制功能是封装在一个Javabean中,JSP程序使用scope=application来调用这个Javabean,这样,具备控制功能的javabean就类似servlet常驻内存,并和后台各种中间件交互操作。

“首页”的展现

在实际应用中,我们经常有多个用户要同时访问一个页面,如首页,这个首页中有很多功能要运行,比如目录分类,首页程序要从数据库中读入树形数据并展开,输出到首页,这个功能是封装在Javabean中的。

那么首页JSP程序调用这个Javabean时,使用scope=application, 再通过树形数据的缓冲算法,这样,多个用户同时访问首页时,首页JSP程序就无需每次启动Javabean然后再反复读取数据库了。无疑大大提高速度。

所以如果你的首页JSP访问量很高,那么就应该在这方面多花点时间优化。

数据库连接缓冲

  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程序的实际运行中,使用Application缓存数据库的连接,每次使用时,从缓冲中取出,用完就返回。

正文到此结束
Loading...