溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

在JSP程序中Application怎么用

發(fā)布時(shí)間:2021-11-03 11:29:54 來(lái)源:億速云 閱讀:147 作者:小新 欄目:編程語(yǔ)言

這篇文章主要介紹在JSP程序中Application怎么用,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!

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

MVC中控制功能

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

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

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

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

在實(shí)際應(yīng)用中,我們經(jīng)常有多個(gè)用戶(hù)要同時(shí)訪(fǎng)問(wèn)一個(gè)頁(yè)面,如首頁(yè),這個(gè)首頁(yè)中有很多功能要運(yùn)行,比如目錄分類(lèi),首頁(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è)用戶(hù)同時(shí)訪(fǎng)問(wèn)首頁(yè)時(shí),首頁(yè)JSP程序就無(wú)需每次啟動(dòng)Javabean然后再反復(fù)讀取數(shù)據(jù)庫(kù)了。無(wú)疑大大提高速度。

所以如果你的首頁(yè)JSP訪(fǎng)問(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í),從緩沖中取出,用完就返回。

以上是“在JSP程序中Application怎么用”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對(duì)大家有幫助,更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI