首 页文章中心下载中心客户留言老站入口
您当前的位置:网页制作文章中心网络编程JSP教程 → 文章内容 退出登录 用户管理
本类热门文章
相关下载
在JSP编程中Application的使用方法详解
作者:佚名  来源:不详  发布时间:2008-8-12 18:56:48

减小字体 增大字体

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访问量很高,那么就应该在这方面多花点时间优化。

数据库连接缓冲


%26lt; jsp:useBean id=cods
  class=oracle.jdbc.pool.OracleConnectionCacheImpl
  scope=application /%26gt;

%26lt; event:application_OnStart%26gt;
%26lt; %
cods.setURL(jdbc:oracle:thin:@HOST:PORT:SID);
cods.setUser(scott);
cods.setPassword(tiger);
cods.setStmtCache (5);
%%26gt;
%26lt; /event:application_OnStart%26gt;

%26lt; %@ page import=java.sql.*, javax.sql.*, oracle.jdbc.pool.* %%26gt;
%26lt; !----------------------------------------------------------------
* 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.

--------------------------------------------------------------------!%26gt;
%26lt; HTML%26gt;
%26lt; HEAD%26gt;
%26lt; TITLE%26gt;
ConnCache JSP
%26lt; /TITLE%26gt;
%26lt; /HEAD%26gt;
%26lt; BODY BGCOLOR=EOFFFO%26gt;
%26lt; H1%26gt; Hello
%26lt; %= (request.getRemoteUser() != null? , +
request.getRemoteUser() : ) %%26gt;
! I am Connection Caching JSP.
%26lt; /H1%26gt;
%26lt; HR%26gt;
%26lt; B%26gt; I get the Connection from the Cache and recycle it back.
%26lt; /B%26gt;
%26lt; P%26gt;
%26lt; %
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()) {
%%26gt;
%26lt; TABLE BORDER=1 BGCOLOR=C0C0C0%26gt;
%26lt; TH WIDTH=200 BGCOLOR=white%26gt; %26lt; I%26gt;Employee Name%26lt; /I%26gt; %26lt; /TH%26gt;
%26lt; TH WIDTH=100 BGCOLOR=white%26gt; %26lt; I%26gt;Salary%26lt; /I%26gt; %26lt; /TH%26gt;
%26lt; TR%26gt; %26lt; TD ALIGN=CENTER%26gt; %26lt; %= rset.getString(1) %%26gt; %26lt; /TD%26gt;
%26lt; TD ALIGN=CENTER%26gt; $%26lt; %= rset.getDouble(2) %%26gt; %26lt; /TD%26gt;
%26lt; /TR%26gt;
%26lt; % while (rset.next()) {
%%26gt;
%26lt; TR%26gt; %26lt; TD ALIGN=CENTER%26gt; %26lt; %= rset.getString(1) %%26gt; %26lt; /TD%26gt;
%26lt; TD ALIGN=CENTER%26gt; $%26lt; %= rset.getDouble(2) %%26gt; %26lt; /TD%26gt;
%26lt; /TR%26gt;
%26lt; % }
%%26gt;
%26lt; /TABLE%26gt;
%26lt; % }
else {
%%26gt;
%26lt; P%26gt; Sorry, the query returned no rows! %26lt; /P%26gt;
%26lt; %
}
rset.close();
stmt.close();
conn.close(); // Put the Connection Back into the Pool
} catch (SQLException e) {
out.println(%26lt; P%26gt; + There was an error doing the query:);
out.println (%26lt; PRE%26gt; + e + %26lt; /PRE%26gt;
%26lt; P%26gt;);
}
%%26gt;
%26lt; /BODY%26gt;
%26lt; /HTML%26gt;


使用application缓存数据库的连接,每次使用时,从缓冲中取出,用完就返回。

[] [返回上一页] [打 印]
文章评论 (评论内容只代表网友观点,与本站立场无关!)

用户名: 查看更多评论

分 值:100分 85分 70分 55分 40分 25分 10分 0分

内 容:

         (注“”为必填内容。) 验证码: 验证码,看不清楚?请点击刷新验证码

关于本站 - 网站帮助 - 广告合作 - 下载声明 - 友情连接 - 网站地图 - 管理登陆 yn11 QQ:1003368401