欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

程序员文章站 2022-06-15 15:53:42
(sun企业级应用的首选)调用javeabean命令usebean中有scope设置,一般有application session page等设置,page就是每页重新产生useb...

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