JNDI介绍(详解,什么是JNDI)

转载 2012年03月23日 15:33:52
JNDI介绍(详解,什么是JNDI)
JNDI(Java Naming and Directory Interface)是一个应用程序设计的API,为开发人员提供了查找和访问各种命名和目录服务的通用、统一的接口,类似JDBC都是构建在抽象层上。
JNDI可访问的现有的目录及服务有:
DNS、XNam 、Novell目录服务、LDAP(Lightweight Directory Access Protocol 轻型目录访问协议)、 CORBA对象服务、文件系统、Windows XP/2000/NT/Me/9x的注册表、RMI、DSML v1&v2、NIS。
JNDI优点:
包含了大量的命名和目录服务,使用通用接口来访问不同种类的服务;
可以同时连接到多个命名或目录服务上;
建立起逻辑关联,允许把名称同Java对象或资源关联起来,而不必指导对象或资源的物理ID。
JNDI程序包:




javax.naming:命名操作;
javax.naming.directory:目录操作;
javax.naming.event:在命名目录服务器中请求事件通知;
javax.naming.ldap:提供LDAP支持;
javax.naming.spi:允许动态插入不同实现。




利用JNDI的命名与服务功能来满足企业级APIs对命名与服务的访问,诸如EJBs、JMS、JDBC 2.0以及IIOP上的RMI通过JNDI来使用CORBA的命名服务。
JNDI与JDBC:
JNDI提供了一种统一的方式,可以用在网络上查找和访问服务。通过指定一个资源名称,该名称对应于数据库或命名服务中的一个纪录,同时返回数据库连接建立所必须的信息。
代码示例:




try{
Context cntxt = new InitialContext();
DataSource ds = (DataSource) cntxt.lookup("jdbc/dpt");
}
catch(NamingException ne){
...
}




JNDI与JMS:
消息通信是软件组件或应用程序用来通信的一种方法。JMS就是一种允许应用程序创建、发送、接收、和读取消息的JAVA技术。
代码示例:




try{
Properties env = new Properties();
InitialContext inictxt = new InitialContext(env);
TopicConnectionFactory connFactory = (TopicConnectionFactory) inictxt.lookup("TTopicConnectionFactory");
...
}
catch(NamingException ne){
...
}




访问特定目录:举个例子,人是个对象,他有好几个属性,诸如这个人的姓名、电话号码、电子邮件地址、邮政编码等属性。通过getAttributes()方法






Attribute attr =
    directory.getAttributes(personName).get("email");
String email = (String)attr.get();




通过使用JNDI让客户使用对象的名称或属性来查找对象:




foxes = directory.search("o=Wiz,c=US", "sn=Fox", controls);




通过使用JNDI来查找诸如打印机、数据库这样的对象,查找打印机的例子:




Printer printer = (Printer)namespace.lookup(printerName);
printer.print(document);




浏览命名空间:




NamingEnumeration list = namespace.list("o=Widget, c=US");
while (list.hasMore()) {
NameClassPair entry = (NameClassPair)list.next();
display(entry.getName(), entry.getClassName());
}




常用的JNDI操作:




void bind(String sName,Object object);――绑定:把名称同对象关联的过程
void rebind(String sName,Object object);――重新绑定:用来把对象同一个已经存在的名称重新绑定
void unbind(String sName);――释放:用来把对象从目录中释放出来
void lookup(String sName,Object object);――查找:返回目录总的一个对象
void rename(String sOldName,String sNewName);――重命名:用来修改对象名称绑定的名称
NamingEnumeration listBinding(String sName);――清单:返回绑定在特定上下文中对象的清单列表
NamingEnumeration list(String sName);




代码示例:重新得到了名称、类名和绑定对象。




NamingEnumeration namEnumList = ctxt.listBinding("cntxtName");
...
while ( namEnumList.hasMore() )   {
Binding bnd = (Binding) namEnumList.next();
String sObjName = bnd.getName();
String sClassName = bnd.getClassName();
SomeObject objLocal = (SomeObject) bnd.getObject();
}


 


JNDI连接数据库模型






package DBUtil;


import java.sql.Connection;
import java.sql.Statement;
import java.sql.ResultSet;
import java.sql.SQLException;
import javax.sql.DataSource;
import javax.naming.Context;
import javax.naming.InitialContext;


public class DBConnection {
    private Connection conn = null;
    private Statement stmt = null;
    private ResultSet rs = null;
    private int resultNum = 0;


    /**
     * 构造函数
     * 找到数据源,并用这个数据源创建连接
     */
    public DBConnection() {
        try {
            Context ctx = new InitialContext();
     if (ctx == null) throw new Exception("No Context");
     DataSource ds = (DataSource)ctx.lookup("java:comp/env/jdbc/oracle");
            if (ds == null) throw new Exception("jdbc/oracle is an unknown DataSource");
            conn = ds.getConnection();
            stmt = conn.createStatement();
        } catch (Exception e) {
            System.out.println("naming:" + e.getMessage());
        }
    }












    /**
     * 执行SQL语句:查询记录
     * @param sql SQL语句
     * @return ResultSet 记录集
     */
    public ResultSet executeQuery(String sql) {
        rs = null;
        try {
            rs = stmt.executeQuery(sql);
        } catch(SQLException se) {
            System.out.println("Query error:" + se.getMessage());
        }
        return rs;
    }


    /**
     * 执行SQL语句 :插入与更新记录
     * @param sql SQL语句
     * @return int resultNum 更新的记录数
     */
    public int executeUpdate(String sql) {
        resultNum=0;
        try {
            resultNum = stmt.executeUpdate(sql);
        } catch (SQLException se) {
            System.err.println("Update error:" + se.getMessage());
        }
        return resultNum;
    }


    /**
     * 关闭连接
     */
    public void close() {
        try {
            if (rs != null) {
                rs.close();
                rs = null;
            }
            if (stmt != null) {
               stmt.close();
               stmt = null;
            }
            if (conn != null) {
                conn.close();
                conn = null;
            }
        } catch (SQLException se) {
            System.out.println("close error:" + se.getMessage());
        }
    }


java中的JNDI详解

java中实现JNDI的接口: javax.naming.Context和它的实现类javax.naming.InitialContext 开始的版本: @since JNDI 1.1 / Jav...
  • qq383264679
  • qq383264679
  • 2016年04月22日 10:02
  • 3297

JNDI介绍(详解,什么是JNDI)

JNDI介绍(详解,什么是JNDI)JNDI(Java Naming and Directory Interface)是一个应用程序设计的API,为开发人员提供了查找和访问各种命名和目录服务的通用、统...
  • russule
  • russule
  • 2008年11月27日 11:24
  • 280

JNDI介绍(详解,什么是JNDI)

 JNDI介绍(详解,什么是JNDI)连数据库时有用的,Java Naming and Directory InterfaceJNDI(Java Naming and Directory Interf...
  • SmartTony
  • SmartTony
  • 2007年11月10日 20:01
  • 1762

JNDI是用来做什么的?

.什么是JDNI     1.java Naming and Directory Interface,java命名和目录接口      2.是一组在Java应用中访问命名和目录服务的API      ...
  • Blessed_
  • Blessed_
  • 2017年05月30日 10:53
  • 761

JNDI 源码解析

1.在源码解析之前,了解下JNDI。JNDI(Java Naming and Directory Interface,Java 命名和目录服务接口)是用于从Java应用程序中访问名称和目录服务的一组A...
  • luohong722
  • luohong722
  • 2010年10月08日 17:36
  • 1336

Spring的JNDI数据源连接池配置学习笔记

Spring的JNDI数据源连接池
  • u013960139
  • u013960139
  • 2016年07月05日 11:24
  • 656

JavaEE规范学习(一)--- JNDI

JNDI(JavaNaming and Directory Interface,Java命名和目录接口)是SUN公司提供的一种标准的Java命名系统接口,JNDI提供统一的客户端API,通过不同的访问...
  • Senior_lee
  • Senior_lee
  • 2016年04月05日 21:58
  • 1116

jndi通俗理解

看别人写的文章,对于刚接触jndi来说,理解还是有点困难的,主要我们不知道他们底层是怎么实现的,但是听了牛人给我们稍稍简介了一下,马上就顿悟了,下面我举一个例子。1、我们用jboss配置数据库连接来说...
  • wanhonghui
  • wanhonghui
  • 2010年10月27日 17:17
  • 591

通过JNDI访问WAS中定义的资源

在近期的国库B/S项目中,需要设计大量的报表,而定义报表往往需要指定数据库连接。一般情况下,JDBC连接已经足够。但由于当前项目所使用的DB2数据库的License只允许最大5个用户并发,因此,通过J...
  • tttk
  • tttk
  • 2007年06月02日 22:43
  • 1932

Java之JNDI详解

JNDI的基本应用         JNDI是Java Naming and Directory Interface(JAVA命名和目录接口)的英文简写,它是为JAVA应用程序提供命名和目录访问服...
  • u010430304
  • u010430304
  • 2017年01月18日 15:01
  • 2102
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:JNDI介绍(详解,什么是JNDI)
举报原因:
原因补充:

(最多只允许输入30个字)