JNDI在JAVA WEB工程中的配置

第一步:配置WEB工程的WEB.XMLjava

<resource-ref>
  <description>DB Connection</description>
<res-ref-name>TEST_DATASOURCE</res-ref-name>
<res-type>javax.sql.DataSource</res-type>
<res-auth>Container</res-auth>
</resource-ref>


第二步:配置Tomcat對應的server.xml(如下以ORACLE爲例,其餘DB同理)web

<Context docBase="E:\dev\apps\apache-tomcat-7.0.42\webapps\Test" path="/Test" reloadable="true" source="org.eclipse.jst.jee.server:Test">
<Resource
      name="TEST_DATASOURCE"
      auth="Container"
      type="javax.sql.DataSource"
      driverClassName="oracle.jdbc.driver.OracleDriver"
      url="jdbc:oracle:thin:@IP:端口:數據庫名稱"
      username="用戶名"
      password="密碼"
      maxActive="20"
      maxIdle="2"
      maxWait="-1"/>
</Context>


第三步:貼上我工程JNDI部分示例代碼sql

static DataSource getDataSource(String dsName) {
    DataSource ds = null;
    try {
      if (ServerDetector.isTomcat()) {
        dsName = "java:comp/env/" + dsName;
      }
      ds = (DataSource)JNDIUtil.getInitialContext().lookup(dsName);
    } catch (NamingException e) {
      throw new DataAccessException(e);
    }
    if (null == ds) {
      throw new DataAccessException("data source[" + dsName + "] is null");
    }
    return ds;
  }


注意事項:數據庫

一、上述的數據源名稱TEST_DATASOURCE必定要一致!apache

二、server.xml中配置的內容,會在myeclipse執行clean操做的時候強制執行還原server.xml內容的操做,必定要記得從新配置!tomcat

相關文章
相關標籤/搜索