· [Java论坛][安全论坛][数据库论坛][操作系统论坛]
· [专题] IBM Rational高峰论坛 Windows 7十大功能
· [专题] 史上就危险7月 微软 BizSpark 计划介绍
· [IT技术周刊][IT资源下载专区][病毒求助专区]
· [热点] 我也能做CTO_赛迪连载 赛迪七夕特别行动
· [热点] Chrome 4.0采用V8引擎 Java开发编程规范

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

发布时间:2007.07.20 06:12     来源:赛迪网技术社区    作者:dxaw

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

(责任编辑:龚勋)


[ 发表评论 ] 字体[  ] [ 打印 ] [ 进入博客 ] [ 进入论坛 ]  [ 推荐给朋友 ]
  相关文章
· 用JSP实现数据库图片的存储与显示实例 (07-18) · 使用Resin在NT环境下配置JSP环境 (07-17)
· 对JSP数据库连接类使用方法的详细讲解 (07-13) · 使用 NetBeans IDE 5.0开发JSP快速入门 (07-11)
· Taglib 原理和实现之嵌套和属性的读取 (07-10) · 谈应用于JSP网络编程的安全问题 (07-09)
· 新手入门:在JSP页面中的几种传参方式 (07-09) · JSP实现JDOM处理数据库到XML转换的应用 (07-04)
· 用XML+JSP实现网页内容动态显示的方案 (07-04) · 专题:JSP--当今最流行的动态网站开发技术 (07-02)
  客户需求反馈表
* 姓  名:
更多资料  了解方案  认识厂商
* 单位名称:
* 联系电话:
* 电子邮件:
资讯 通信 IT产品 IT技术 信息化
专题:扭亏为盈 联想09年Q2翻番
·专题:Tech·Ed 2009微..
·直播:2009互联网大会..
·迅雷搜狐"互搏" 谁动了..
专题:诺基亚危局已现 或重蹈摩托覆辙
·六股势力角逐4G标准 中..
·专题:联通iPhone并不贵..
·专题:排排坐开商店 三..
商务演示需求分析 多媒体会议室必备投影
·VMware在京隆重举行2009..
·专题:笔记本频道10月热..
·专题:学生机市场 惠普 ..
专题:Tech.Ed 2009微软技术大会
·专题:2009 SYBASE 亚太..
·专题:微软新一代桌面操..
·专题:2009年第3届CSDN..