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

开发 后端
本文叙述在JSP编程中Application的使用方法详解,包括MVC中控制功能和数据库连接缓冲等。

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

数据库连接缓冲

  1. <jsp:useBean id="cods"   
  2.   class="oracle.jdbc.pool.OracleConnectionCacheImpl"    
  3.   scope="application" />   
  4. <event:application_OnStart>   
  5. <%    
  6. cods.setURL("jdbc:oracle:thin:@HOST:PORT:SID");   
  7. cods.setUser("scott");   
  8. cods.setPassword("tiger");   
  9. cods.setStmtCache (5);    
  10. %>   
  11. event:application_OnStart>   
  12. <%@ page import="java.sql.*, javax.sql.*, oracle.jdbc.pool.*" %> 
  13. * This is a JavaServer Page that uses Connection Caching over   
  14. application   
  15. * scope. The Cache is created in an application scope in   
  16. globals.jsa file.    
  17. * Connection is obtained from the Cache and recycled back once   
  18. done.   
  19. <HTML>    
  20. <HEAD>    
  21. <TITLE>   
  22. ConnCache JSP   
  23. TITLE>   
  24. HEAD>   
  25. <BODY BGCOLOR=EOFFFO>    
  26. <H1> Hello    
  27. <%= (request.getRemoteUser() != null? ", " +   
  28. request.getRemoteUser() : "") %>   
  29. ! I am Connection Caching JSP.   
  30. H1>   
  31. <HR>   
  32. <B> I get the Connection from the Cache and recycle it back.   
  33. B>    
  34. <P>   
  35. <%   
  36. try {   
  37. Connection conn = cods.getConnection();   
  38. Statement stmt = conn.createStatement ();   
  39. ResultSet rset = stmt.executeQuery ("SELECT ename, sal " +    
  40. "FROM scott.emp ORDER BY ename");   
  41. if (rset.next()) {   
  42. %>   
  43. <TABLE BORDER=1 BGCOLOR="C0C0C0">   
  44. <TH WIDTH=200 BGCOLOR="white"> <I>Employee NameI> TH>   
  45. <TH WIDTH=100 BGCOLOR="white"> <I>SalaryI> TH>   
  46. <TR> <TD ALIGN=CENTER> <%= rset.getString(1) %> TD>   
  47. <TD ALIGN=CENTER> $<%= rset.getDouble(2) %> TD>   
  48. TR>   
  49. <% while (rset.next()) {   
  50. %>   
  51. <TR> <TD ALIGN=CENTER> <%= rset.getString(1) %> TD>   
  52. <TD ALIGN=CENTER> $<%= rset.getDouble(2) %> TD>   
  53. TR>   
  54. <% }   
  55. %>   
  56. TABLE>   
  57. <% }    
  58. else {   
  59. %>   
  60. <P> Sorry, the query returned no rows! P>   
  61. <%    
  62. }   
  63. rset.close();   
  64. stmt.close();   
  65. conn.close(); // Put the Connection Back into the Pool   
  66. } catch (SQLException e) {   
  67. out.println("<P>" + "There was an error doing the query:");   
  68. out.println ("<PRE>" + e + "PRE> n <P>");   
  69. }   
  70. %>   
  71. BODY>   
  72. HTML> 

【编辑推荐】

  1. JSP和Servlet中的几个编码的作用及原理
  2. 在JSP页面中的应用JavaBean
  3. 对JSP中的内置对象简单概述
  4. 使用JSP include机制改进外观
  5. JSP的特点和其它动态网页开发技术比较
责任编辑:佚名 来源: builder
相关推荐

2010-03-10 11:11:16

Python编程

2009-06-16 15:20:48

ApplicationJSP程序

2010-10-09 10:30:03

JS event

2019-11-07 23:48:12

shell脚本getopts

2009-12-02 16:04:44

PHP fsockop

2012-05-10 10:53:10

Linuxhistory

2010-03-19 14:28:58

Java Socket

2023-06-28 08:34:02

Bind()函数JavaScript

2009-06-08 20:07:44

Eclipse中使用p

2009-12-28 13:28:03

WPF视频

2009-11-30 17:43:54

PHP split()

2010-03-10 19:18:10

Python scri

2011-08-30 13:49:57

Qt数据库QTableView

2023-05-11 08:00:44

Golangsync.Pool

2009-08-25 16:54:28

C# RichText

2012-05-09 10:52:37

Linux监控命令

2010-01-28 17:07:03

Android Gal

2010-06-03 17:38:03

Hadoop命令

2010-06-01 19:55:30

SVN使用

2011-08-08 11:40:42

Cocos2d CCLayer Touch
点赞
收藏

51CTO技术栈公众号