之前说到了利用Java中的Properties类读取properties配置文件,连接数据库,现在说另一种方法,他们的目的和作用都是一样的,都是为了提高代码的复用性,解决了更改数据库

时还要更改代码的麻烦。和之前的properties解决的问题一样这里就不说了,详见前一篇文章:Java读取properties文件连接数据库

jndi是什么?

JNDI(Java Naming and Directory Interface,Java命名和目录接口)是SUN公司提供的一种标准的Java命名系统接口,JNDI提供统一的客户端API,通过不同的访问提供者接口JNDI服务供应接口(SPI)的实现。

我们能做的就是拿来直接用

这是Tomcat网站上给我们的提示,告诉我们怎么配置,还有一些模板:https://tomcat.apache.org/tomcat-7.0-doc/jndi-resources-howto.html

下面还是我的mail项目,在eclipse中用jndi连接数据库(获取数据库连接)执行操作

在eclipse中建的web项目会有WebContent目录,MyEclipse中是WebRoot目录,其实都是一样的,在目录下有META-INF文件夹,在里面新建context.xml输入以下内容

<?xml version="1.0" encoding="UTF-8"?>
<Context>
<Resource name="jdbc/mail"
auth="Container"
type="javax.sql.DataSource"
maxActive="100"
maxIdle="30"
maxWait="10000"
username="root"
password="root"
driverClassName="com.mysql.jdbc.Driver"
url="jdbc:mysql://localhost:3306/mail"/>
<
  • driverClassName -
    要使用的JDBC驱动程序的完全限定的Java类名称。
  • username
    - 要传递给我们的JDBC驱动程序的数据库用户名。
  • password
    - 要传递给我们的JDBC驱动程序的数据库密码。
  • url -
    要传递给我们的JDBC驱动程序的连接URL。(为了向后兼容,该属性driverName 也被识别。)
  • initialSize -
    池初始化期间将在池中创建的初始连接数。默认值:0
  • maxActive -
    可以同时从此池分配的最大连接数。默认值:8
  • minIdle -
    同时在此池中闲置的最小连接数。默认值:0
  • maxIdle -
    可以同时在该池中闲置的最大连接数。默认值:8
  • maxWait -
    抛出异常之前要返回的连接的池将等待的最大毫秒数(当没有可用连接时)。默认值:-1(无限)
  • name
    - 数据源名称,可以随便定义注意要和后面的web.xml文件中的一致
  • auth - 这个官方也没有给出……没找到

接下来在WEB-INF中的web.xml文件中添加一些内容

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

里面的res-ref-name中的属性值要和之前的context.xml中的name是一致的,还有auth属性也要一致,这样才能找到。

直接把之前写的获取数据库连接的类改了

package util;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException; import javax.naming.Context;
import javax.naming.InitialContext;
import javax.naming.NamingException;
import javax.sql.DataSource; public class ConnectionManager {
public static Connection getConnection() {
Connection conn = null;
try {
// 初始化查找命名空间
Context ctx = new InitialContext();
// InitialContext ctx = new InitialContext();//也可以
// 找到DataSource,对名称进行定位java:comp/env是固定的,后面跟的是在配置文件中定义的name
DataSource ds = (DataSource) ctx.lookup("java:comp/env/jdbc/mail");
//获取数据库连接
conn = ds.getConnection();
System.out.println("connection connected !");
} catch (NamingException e) {
System.out.println(e.getMessage());
} catch (SQLException e) {
e.printStackTrace();
}
return conn;
}
}

运行项目,得到connection connected !输出,查看数据库表中数据,添加成功。

用JNDI连接数据库的更多相关文章

  1. tomcat6配置jndi连接数据库的方式

    eworkflow工作流+eform表单+ebiao报表集成在一起,用tomcat6发布,并用jndi连接数据库,数据库是sqlserver2005,配置如下: 1.在tomcat6\conf\con ...

  2. 使用JNDI连接数据库

    第一步:实现一个Java类: package com.logistic.data; import java.sql.*;import javax.sql.*;import javax.naming.* ...

  3. JNDI连接数据库的详细步骤 以及简要的c3po数据库连接的配置

    第一步在tomcat的context.xml文件中配置数据源:context.xml的路径形式是:D:\Program Files (x86)\apache-tomcat-6.0.44\conf\co ...

  4. Tomcat,Jboss,Weblogic通过jndi连接数据库

    1.  Tomcat配置Jndi数据源 1.1在tomcat服务器的lib目录下加入数据库连接的驱动jar包 1.2修改tomcat服务器的conf目录下server.xml配置文件 编辑server ...

  5. jndi连接数据库配置过程总结

    一.我们先找到tomcat安装目录中conf目录下的context.xml更改里面的内容: <?xml version='1.0' encoding='utf-8'?> <Conte ...

  6. Quartz集群配置

    先看看quartz的持久化基本介绍: 引用 1 大家都清楚quartz最基本的概念就是job,在job内调用具体service完成具体功能,quartz需要把每个job存储起来,方便调度,quartz ...

  7. javax.naming.NoInitialContextException错误的解决方案

    今天,学习用了一下nutz框架,写了一个HelloWorld的小程序,在用jndi配置数据源时,写了一个测试类,并在main方法中调用了jndi获得数据库连接,但是报错了,错误信息如下: javax. ...

  8. javax.naming.NoInitialContextException: Need to specify class name in environment or system property

    javax.naming.NoInitialContextException: Need to specify class name in environment or system property ...

  9. Tomcat 配置连接池

    1. Tomcat 配置 JNDI 资源 JNDI(Java Naming and Directory Interface), Java 命名和目录接口; JNDI 作用: 在服务器上配置资源, 然后 ...

随机推荐

  1. webpack代码分离 ensure 看了还不懂,你打我(转)

    webpack异步加载的原理 webpack ensure相信大家都听过.有人称它为异步加载,也有人说做代码切割,那这 个家伙到底是用来干嘛的?其实说白了,它就是把js模块给独立导出一个.js文件的, ...

  2. AutoMapper 使用心得

    在很久之前就已经有了解到AutoMapper 这一个组件了,但是却一直不明白这个东西要怎么使用,是用来干什么的.经过几经周折之后,看了资料大概5.6次吧,总算理解其中的用途和原理(请原谅我理解能力太差 ...

  3. equals 与 == 区别及用法

    ==: 1. ==操作符专门用来比较两个变量的值是否相等,也就是用于比较变量所对应的内存中所存储的数值是否相同: 2.如果要比较两个变量是否指向同一个对象,这时候就需要用==操作符进行比较: 注意:= ...

  4. ubuntu11.04编译gm8180的ffmpeg

    1.1 About this documentThe ffmpeg is a open source package that provides video application for gener ...

  5. 一种在BIOS中嵌入应用程序的方法及实现

    本文针对Award公司开发的计算机系统BIOS提出了一种嵌入应用程序的方法,其基本原理对别的品牌的BIOS也一样适用,仅需稍加修改.文中作者给出并讨论一个完整的例子程序,该程序已经通过实验验证.  正 ...

  6. freemarker写select组件(四)

    freemarker写select组件 1.宏定义 <#macro select id datas value="" key="" text=" ...

  7. 芝麻HTTP:Python爬虫入门之正则表达式

    1.了解正则表达式 正则表达式是对字符串操作的一种逻辑公式,就是用事先定义好的一些特定字符.及这些特定字符的组合,组成一个"规则字符串",这个"规则字符串"用来 ...

  8. Codeforces Round #467 (Div. 1) B. Sleepy Game

    我一开始把题目看错了 我以为是博弈.. 这题就是一个简单的判环+dfs(不简单,挺烦的一题) #include <algorithm> #include <cstdio> #i ...

  9. NVIDIA Geforce GT 730 OpenGL 图形显示异常花屏

    原因:C盘空间爆表,用dism++清理.结果用力过猛,清完后程序里的图形直接马赛克了... 上个图感受一下吧... 嘿别说,还有那么点艺术风! 别闹了,这个问题很严重,很严肃好不好! 因为程序和数据都 ...

  10. js常见排序

    <!DOCTYPE html><html><head lang="en"> <meta charset="UTF-8" ...