当前位置:编程学习 > JS >>

在JSP编程中Application的使用方法详解

jsp(SUN企业级应用的首选)调用Javeabean命令UseBean中有Scope设置,一般有Application session page等设置,Page就是每页

重新产生usebean中的javabean新对象,一般情况是用这种,如果多个jsp(SUN企业级应用的首选)程序间为共享数据,可以使用

session

而application的意思,该javabean将一直存在,与session相对用户来说,application是相对应用程序

的,一般来说,一个用户有一个session,并且随着用户离开而消失;而application则是一直存在,类似

一个servlet程序,类似整个系统的"全局变量",而且只有一个实例。

MVC中控制功能

因此application这个特性,很适合用来做MVC中的控制功能,一般传统MVC是用servlet做控制功能,V基

本是jsp(SUN企业级应用的首选)页面,M就是中间件Javabean之类。

但是随着jsp(SUN企业级应用的首选)功能的完善和推广,逐渐有替代servlet之趋势,我们在实践中更多使用的也是jsp(SUN企业级应用的首选),有时为

了省却麻烦的事情,就使用jsp(SUN企业级应用的首选)代替servlet.尤其是其控制功能。

实际上,这个控制功能是封装在一个Javabean中,jsp(SUN企业级应用的首选)使用scope=application来调用这个Javabean,这样

,具备控制功能的javabean就类似servlet常驻内存,并和后台各种中间件交互操作。

“首页”的展现

在实际应用中,我们经常有多个用户要同时访问一个页面,如首页,这个首页中有很多功能要运行,比如

目录分类,首页程序要从数据库中读入树形数据并展开,输出到首页,这个功能是封装在Javabean中的。

那么首页jsp(SUN企业级应用的首选)调用这个Javabean时,使用scope=application, 再通过树形数据的缓冲算法,这样,多个用

户同时访问首页时,首页jsp(SUN企业级应用的首选)就无需每次启动Javabean然后再反复读取数据库了。无疑大大提高速度。

所以如果你的首页jsp(SUN企业级应用的首选)访问量很高,那么就应该在这方面多花点时间优化。

数据库连接缓冲


< jsp(SUN企业级应用的首选):useBean id="cods"
  class="Oracle(大型网站数据库平台).jdbc.pool.Oracle(大型网站数据库平台)ConnectionCacheImpl"
  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(SUN企业级应用的首选)
< /TITLE>
< /HEAD>
< BODY BGCOLOR=EOFFFO>
< H1> Hello
< %= (request.getRemoteUser() != null? ", " +
request.getRemoteUser() : "") %>
! I am Connection Caching jsp(SUN企业级应用的首选).
< /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>
< P>");
}
%>
< /BODY>
< /HTML>

补充:Web开发 , Jsp ,
CopyRight © 2012 站长网 编程知识问答 www.zzzyk.com All Rights Reserved
部份技术文章来自网络,