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

来源:互联网 发布:软件评测师难考吗 编辑:程序博客网 时间:2024/05/29 18:24

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());        }    }} 




转载地址:http://www.cnblogs.com/beyondwcm/archive/2007/11/14/958868.html

原创粉丝点击