在JSP程序中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ù)連接緩沖
- <jsp:useBean id="cods"
- class="oracle.jdbc.pool.OracleConnectionCacheImpl"
- scope="application" />
- <event:application_OnStart>
- <%
- cods.setURL("jdbc:oracle:thin:@HOST:PORT:SID");
- cods.setUser("scott");
- cods.setPassword("tiger");
- cods.setStmtCache (5);
- %>
- </event:application_OnStart>
- <%@ page import="java.sql.*, javax.sql.*, oracle.jdbc.pool.*" %>
- <!----------------------------------------------------------------
- * This is a JavaServer Page that uses Connection Caching over
- application
- * scope. The Cache is created in an application scope in
- globals.jsa file.
- * Connection is obtained from the Cache and recycled back once
- done.
- --------------------------------------------------------------------!>
- <HTML>
- <HEAD>
- <TITLE>
- ConnCache JSP
- </TITLE>
- </HEAD>
- <BODY BGCOLOR=EOFFFO>
- <H1> Hello
- <%= (request.getRemoteUser() != null? ", " +
- request.getRemoteUser() : "") %>
- ! I am Connection Caching JSP.
- </H1>
- <HR>
- <B> I get the Connection from the Cache and recycle it back.
- </B>
- <P>
- <%
- try {
- Connection conn = cods.getConnection();
- Statement stmt = conn.createStatement ();
- ResultSet rset = stmt.executeQuery ("SELECT ename, sal " +
- "FROM scott.emp ORDER BY ename");
- if (rset.next()) {
- %>
- <TABLE BORDER=1 BGCOLOR="C0C0C0">
- <TH WIDTH=200 BGCOLOR="white"> <I>Employee Name</I> </TH>
- <TH WIDTH=100 BGCOLOR="white"> <I>Salary</I> </TH>
- <TR> <TD ALIGN=CENTER> <%= rset.getString(1) %> </TD>
- <TD ALIGN=CENTER> $<%= rset.getDouble(2) %> </TD>
- </TR>
- <% while (rset.next()) {
- %>
- <TR> <TD ALIGN=CENTER> <%= rset.getString(1) %> </TD>
- <TD ALIGN=CENTER> $<%= rset.getDouble(2) %> </TD>
- </TR>
- <% }
- %>
- </TABLE>
- <% }
- else {
- %>
- <P> Sorry, the query returned no rows! </P>
- <%
- }
- rset.close();
- stmt.close();
- conn.close(); // Put the Connection Back into the Pool
- } catch (SQLException e) {
- out.println("<P>" + "There was an error doing the query:");
- out.println ("<PRE>" + e + "</PRE> \n <P>");
- }
- %>
- </BODY>
- </HTML>
在JSP程序的實(shí)際運(yùn)行中,使用Application緩存數(shù)據(jù)庫(kù)的連接,每次使用時(shí),從緩沖中取出,用完就返回。
【編輯推薦】