JNDI常见配置方式

  1. 概念

   JNDI(Java Naming and Directory Interface,Java命名和目录接口)是一组在Java应用中访问命名和目录服务的API。命名服务将名称和对象联系起来,使得我们可以用名称访问对象。目录服务是一种命名服务,在这种服务里,对象不但有名称,还有属性。

  1. Eclipse配置JNDI
    1. 全局配置

1)在Eclipse中选择Servers下的context.xml配置文件中加入:

<Resource

  name="jdbc/mysql"

  type="javax.sql.DataSource"

  maxActive="100"

  maxIdle="30"

  maxWait="5000"

  username="root"//对应的数据库账号密码

  password="root"

  driverClassName="com.mysql.jdbc.Driver"

  url="jdbc:mysql://localhost:3306/news"/>

 

 

2)在项目的web.xml中加入资源引用:

<resource-ref>

                  <description>MySQL DB Connection</description>

                  <res-ref-name>jdbc/mysql</res-ref-name>

                  <res-type>javax.sql.DataSource</res-type>

                  <res-auth>Container</res-auth>

</resource-ref>

 

3)jndi测试方法:

         public static Connection getConnection(){

                  Connection connection = null;

                  try {

                          Context ctx = new InitialContext();

                          // 获取与逻辑名相关联的数据源对象

                          DataSource ds = (DataSource) ctx.lookup("java:comp/env/jdbc/mysql");

                          connection = ds.getConnection();

                          System.out.println("connection:"+connection);

 

                  } catch (Exception e) {

                          e.printStackTrace();

                  }

                  return connection;

         }

 

 

4)在jsp中调用加载jndi方式,不可以直接用main方法测试,必须通过启动容器从jsp中调用:

                  <%@page import="java.sql.Connection"%>

                  <%@ page language="java" contentType="text/html; charset=UTF-8"

                 pageEncoding="UTF-8"%>

                  <%

                          DBUtil dbutil = new DBUtil();

                          Connection conn = dbutil.getConnection();

                          out.println("conn:"+conn);

                  %>

 

 

 

    1. 局部配置(不推荐

1)在tomcat的server.xml的<host>标签内,添加:

                  <Context path="/slesson3" docBase="/slesson3">

                     <Resource

                           name="sqlconn"

                           type="javax.sql.DataSource"

driverClassName="com.microsoft.sqlserver.jdbc.SQLServerDriver"

                           maxIdle="2"

                           maxWait="5000"

                           username="sa"

                           password="sa123"

                           url="jdbc:sqlserver://localhost:1433;databasename=j1201"

                           maxActive="4"/>

                  </Context>

其他配置同第一种方式。

 

 

 

    1. 局部配置

1)在项目的META-INFO下面新建context.xml。加入:

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

<Context>

         <Resource

               name="jdbc/mysql"

               type="javax.sql.DataSource"

               maxActive="100"

               maxIdle="30"

               maxWait="5000"

               username="root"

               password="root"

               driverClassName="com.mysql.jdbc.Driver"

               url="jdbc:mysql://localhost:3306/news"/>

</Context>

 

其他配置同第一种方式。

 

 

总结:如果要配置局部的话,推荐使用第三种方式,这样不依赖tomcat了。但是还是推荐使用第一种方式好,虽然依赖tomat,但是是全局的,而且可以配置

多个。对于以后切换使用方便。

在项目的web.xml中添加的资源引用可有可无。

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值