在JSP程序中Application使用浅析
创始人
2024-04-03 00:42:19
0

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.   class="oracle.jdbc.pool.OracleConnectionCacheImpl"   
  2.   scope="application" /> 
  3.  
  4.  
  5.  
  6. <%   
  7. cods.setURL("jdbc:oracle:thin:@HOST:PORT:SID");  
  8. cods.setUser("scott");  
  9. cods.setPassword("tiger");  
  10. cods.setStmtCache (5);   
  11. %> 
  12.  
  13.  
  14.  
  15. <%@ page import="java.sql.*, javax.sql.*, oracle.jdbc.pool.*" %> 
  16.  
  17.  
  18.  
  19.    
  20.    
  21.  <LI class=alt>ConnCache JSP  <LI> 
  22.  
  23.    
  24.  Hello   
  25. <%= (request.getRemoteUser() != null? ", " +  
  26. request.getRemoteUser() : "") %> 
  27. ! I am Connection Caching JSP.  
  28.  

  29.  
  30.  I get the Connection from the Cache and recycle it back.  
  31.    
  32.  
  33.  

  34. <%  
  35. try {  
  36. Connection conn = cods.getConnection();  
  37.  
  38. Statement stmt = conn.createStatement ();  
  39. ResultSet rset = stmt.executeQuery ("SELECT ename, sal " +   
  40. "FROM scott.emp ORDER BY ename");  
  41.  
  42. if (rset.next()) {  
  43. %> 
  44.  
  45.  Employee Name  
  46.  Salary  
  47.   <%= rset.getString(1) %>  
  48.  $<%= rset.getDouble(2) %>  
  49.  
  50.  
  51. <% while (rset.next()) {  
  52. %> 
  53.  
  54.   <%= rset.getString(1) %>  
  55.  $<%= rset.getDouble(2) %>  
  56.  
  57.  
  58. <% }  
  59. %> 
  60.  
  61. <% }   
  62. else {  
  63. %> 
  64.  Sorry, the query returned no rows! 

     
  65.  
  66. <%   
  67. }  
  68. rset.close();  
  69. stmt.close();  
  70. conn.close(); // Put the Connection Back into the Pool  
  71.  
  72. } catch (SQLException e) {  
  73. out.println("

    " + "There was an error doing the query:");  

  74. out.println ("
    " + e + "
     \n 

    ");  

  75. }  
  76. %> 
  77.  
  78.  
  79.  

在JSP程序的实际运行中,使用Application缓存数据库的连接,每次使用时,从缓冲中取出,用完就返回。

 

【编辑推荐】

  1. 教你在JSP中使用JavaMail
  2. 在JSP中动态生成并调用JSP程序
  3. JSTL介绍—JSP编程新组件 允许用标签编程
  4. JSP开发所需要的Eclipse插件及安装配置方法
  5. JDBC与JSP简单模拟MVC三层架构

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...
《非诚勿扰》红人闫凤娇被曝厕所... 【51CTO.com 综合消息360安全专家提醒说,“闫凤娇”、“非诚勿扰”已经被黑客盯上成为了“木...
2012年第四季度互联网状况报... [[71653]]  北京时间4月25日消息,据国外媒体报道,全球知名的云平台公司Akamai Te...