博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Servlet 读取web.xml文件中的配置参数连接数据库
阅读量:6113 次
发布时间:2019-06-21

本文共 3607 字,大约阅读时间需要 12 分钟。

 

web.xml中数据库连接配置:

<?xml version="1.0" encoding="UTF-8"?>

<web-app xmlns:xsi=""
xmlns="" xmlns:web=""
xsi:schemaLocation=" "
id="WebApp_ID" version="2.5">
<display-name>Servelt_ReadingDBFromWebXml</display-name>
<welcome-file-list>
   <welcome-file>index.html</welcome-file>
   <welcome-file>index.htm</welcome-file>
   <welcome-file>index.jsp</welcome-file>
   <welcome-file>default.html</welcome-file>
   <welcome-file>default.htm</welcome-file>
   <welcome-file>default.jsp</welcome-file>
</welcome-file-list>

<!-- 通过getServletContext().getInitParameter("XX")读取 -->

<context-param>
   <param-name>driver</param-name>
   <param-value>com.mysql.jdbc.Driver</param-value>
</context-param>

<context-param>

   <param-name>url</param-name>
   <param-value>jdbc:mysql://localhost:3306/sample</param-value>
</context-param>

<context-param>

   <param-name>username</param-name>
   <param-value>root</param-value>
</context-param>

<context-param>

   <param-name>password</param-name>
   <param-value>admin</param-value>
</context-param>

<servlet>

   <servlet-name>DBServlet</servlet-name>
   <servlet-class>demo.DBServlet</servlet-class>

   <!-- 通过getServletConfig().getInitParameter("XX")读取 -->

   <init-param>
    <param-name>driver</param-name>
    <param-value>com.mysql.jdbc.Driver</param-value>
   </init-param>
   <init-param>
    <param-name>url</param-name>
    <param-value>jdbc:mysql://localhost:3306/sample</param-value>
   </init-param>
   <init-param>
    <param-name>username</param-name>
    <param-value>root</param-value>
   </init-param>
   <init-param>
    <param-name>password</param-name>
    <param-value>admin</param-value>
   </init-param>

</servlet>

<servlet-mapping>

   <servlet-name>DBServlet</servlet-name>
   <url-pattern>/readingDB</url-pattern>
</servlet-mapping>
</web-app>

Servlet代码:

/**

*/
package demo;

import java.io.IOException;

import java.io.PrintWriter;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;

import javax.servlet.ServletException;

import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

/**

* Reading DB Config from web.xml
*/
public class DBServlet extends HttpServlet {

/**

*/
private static final long serialVersionUID = 1L;

private String diverClass;

private String userName;
private String password;
private String url;

@Override

public void init() throws ServletException {
   diverClass = /* getServletConfig(). */getServletContext().getInitParameter("driver");
   userName = /* getServletConfig(). */getServletContext().getInitParameter("username");
   password = /* getServletConfig(). */getServletContext().getInitParameter("password");
   url = /* getServletConfig(). */getServletContext().getInitParameter("url");

   try {

    Class.forName(diverClass);
   } catch (Exception e) {
    e.printStackTrace();
   }

}

@Override

protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
   Connection connection = null;
   PreparedStatement statement = null;

   try {

    connection = DriverManager.getConnection(url, userName, password);
    statement = connection.prepareStatement("select * from customer");
    ResultSet rs = statement.executeQuery();

    PrintWriter printWriter = resp.getWriter();

    while (rs.next()) {
     printWriter.println(rs.getString("id"));
     printWriter.println(rs.getString("name"));
    }
   } catch (SQLException e) {
    e.printStackTrace();
   } finally {
    try {
     if (statement != null) {
      statement.close();
     }

     if (connection != null) {

      connection.close();
     }
    } catch (SQLException e) {
     e.printStackTrace();
    }
   }
}
}

转载于:https://www.cnblogs.com/ilahsa/archive/2012/09/29/2708460.html

你可能感兴趣的文章
Hadoop2.5.0 搭建实录
查看>>
实验吧 recursive write up
查看>>
High-speed Charting Control--MFC绘制图表(折线图、饼图、柱形图)控件
查看>>
go test命令參数问题
查看>>
linux 搜索文本
查看>>
超实用Mac软件分享(二)
查看>>
Android JSON数据解析
查看>>
DEV实现日期时间效果
查看>>
java注解【转】
查看>>
Oracle表分区
查看>>
centos 下安装g++
查看>>
嵌入式,代码调试----GDB扫盲
查看>>
类斐波那契数列的奇妙性质
查看>>
配置设置[Django]引入模版之后报错Requested setting TEMPLATE_DEBUG, but settings are not configured....
查看>>
下一步工作分配
查看>>
Response. AppendHeader使用大全及文件下载.net函数使用注意点(转载)
查看>>
Wait Functions
查看>>
代码描述10313 - Pay the Price
查看>>
jQuery最佳实践
查看>>
centos64i386下apache 403没有权限访问。
查看>>