JSP内置对象application的作用:<获取配置>《转》

 

1.让多个Jsp、servlet共享数据;

Html代码  收藏代码
  1.  <!-- 将i的值自动+1后放入application的变量中 -->  
  2. <%! int i = 0; %>  
  3. <%  
  4.      application.setAttribute("counter",String.valueOf(++i));  
  5. %>  
  6. <!-- 输出i的值 -->  
  7. <%=i%>  

 在另外的jsp页面可以用application.getAttribute("counter")直接获取counter对应的值。

【理解】

我们可以把application理解为一个Map对象,任何Jsp、Servlet都可以把某个变量放入application中保存,并为之指定一个属性名;而该web应用程序里的其他Jsp、Servlet就可以根据该属性名来得到这个变量。

 

2.获得Web应用配置参数:

Jsp页面:访问数据库所使用的驱动、url、用户名、密码均在web.xml中给出。

Html代码  收藏代码
  1. <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>  
  2. <%@page import="java.sql.*"%>  
  3.   
  4. ......  
  5.   
  6. <%  
  7.         //从配置参数中获取驱动  
  8.         String driver = application.getInitParameter("driver");  
  9.         //获取数据库URL  
  10.         String url = application.getInitParameter("url");  
  11.         //获取用户名和密码  
  12.         String user = application.getInitParameter("user");  
  13.         String pass = application.getInitParameter("pass");  
  14.         //注册驱动  
  15.         Class.forName(driver);  
  16.         //获取数据库连接  
  17.         Connection conn = DriverManager.getConnection(url,user,pass);  
  18.         //创建Statement对象  
  19.         Statement stmt = conn.createStatement();  
  20.         //执行查询  
  21.         ResultSet rs = stmt.executeQuery("select * from newsinfo");  
  22. %>  
  23.         <table bgcolor = "9999dd" border="1" align="center">  
  24.         <%  
  25.             //遍历结果集  
  26.             while(rs.next()){  
  27.          %>  
  28.          <tr>  
  29.          <td><%=rs.getString(1) %></td>  
  30.          <td><%=rs.getString(2) %></td>  
  31.          </tr>  
  32.          <%  
  33.             }  
  34.           %>  
  35.         </table>  

 

web.xml中进行如下配置:

Xml代码  收藏代码
  1. <context-param>  
  2.     <param-name>driver</param-name>  
  3.     <param-value>com.mysql.jdbc.Driver</param-value>  
  4. </context-param>  
  5. <context-param>  
  6.     <param-name>url</param-name>  
  7.     <param-value>jdbc:mysql://localhost:3306/javaee</param-value>  
  8. </context-param>  
  9. <context-param>  
  10.     <param-name>user</param-name>  
  11.     <param-value>root</param-value>  
  12. </context-param>  
  13. <context-param>  
  14.     <param-name>pass</param-name>  
  15.     <param-value>root</param-value>  
  16. </context-param>  

 通过这种方式,可以将一些配置信息放在web.xml文件中进行配置,避免使用硬编码方式写在代码中,从而更好的提高了程序的移植性。

posted @ 2018-01-18 10:02  get("新技能")  阅读(1669)  评论(0编辑  收藏  举报