在JSP編程中使用Application的方法

來源:互聯網
上載者:User

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訪問量很高,那麼就應該在這方面多花點時間最佳化。

資料庫連接緩衝

<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>

使用application快取資料庫的串連,每次使用時,從緩衝中取出,用完就返回。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.