JNDI为应用程序提供了标准统一的方式,连接和使用企业中存在的多个对象目录的能力.WeblogiocServer提供了JNDI的实现,客户机可以 和它无缝连接.同一客户机还可以用JNDI API连接到另一命名服务上.Weblogic Server大量利用JNDI树完成其常规功能.如果应用程序使用EJB,那么这个EJB就发布在JNDI树中,类似的其它对象如DataSource对 象,事务对象都发布在JNDI树上.
下面我们来看一下jndi中相关的名词:
命名服务
命名服务(Naming Service)是可以将复杂数据对象或其引用关联到已知名称的机制.然后可以发布这些名称,客户可以使用这些名称查询与它们相关联的数据对象.名称与对 象之间的关联称为绑定.命名服务通常与其它服务(如文件系统,目录和数据库等)集成以提供这种绑定.大家可以从现代图书馆的卡片目录系统来理解命名服务.
连接工厂(Connection Factory)
连接工厂(Connection Factory)是用于产生链接对象,使得J2EE组件可以访问资源的一种对象。比如,用于数据库的连接工厂是javax.sql.Database对象,它产生java.sql.Connection对象。
常用的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);
操作示例:
package cn.landingbj.queue;
import java.util.Properties;
import javax.naming.*;
public class JNDITest {
public static void main(String[] args) {
Context ctx = null;
Properties properties = new Properties();
properties.put(Context.INITIAL_CONTEXT_FACTORY, "weblogic.jndi.WLInitialContextFactory");
properties.put(Context.PROVIDER_URL, "t3://localhost:7001");
try {
ctx = new InitialContext(properties);
String s = (String) ctx.lookup("name");
String jnditest = "JNDI Test example";
//ctx.unbind("hello yuanrui");
ctx.bind("name", jnditest);
System.out.println(s);
String s1 = "hello yuanrui";
ctx.rebind("name", s1);
s = (String) ctx.lookup("name");
System.out.println(s);
} catch (NamingException e) {
e.printStackTrace();
}
}
}
再次绑定时就会报错:
javax.naming.NameAlreadyBoundException: name is already bound
使用释放绑定
ctx.unbind("hello yuanrui");
貌似没看到效果。。。。。
Jndi数据源测试示例:
public class DBConn {
private static Connection conn;
public static Connection getConn(){
try {
Context ctx = new InitialContext();
DataSource ds = (DataSource) ctx.lookup("smysql");
conn = ds.getConnection();
} catch (Exception e) {
e.printStackTrace();
}
return conn;
}
}
前提是已经配置好数据源 smysql 是绑定jndi的数据源名,经过试验 是可以用来进行数据库操作的
该贴由qq_1414553774380转至本版2014-11-24 18:07:34