用户操作
[留言]  [发消息]  [加为好友] 
订阅我的博客
XML聚合    FeedSky
订阅到鲜果
订阅到Google
订阅到抓虾
deepass_high的公告
文章分类
    存档

    转载  关于JNDI 收藏

    JNDI(Java 命名和目录接口)
    分布式计算环境通常使用命名和目录服务来获取共享的组件和资源。命名和目录服务将名称与位置、服务、信息和资源关联起来。 
    命名服务提供名称—对象的映射。目录服务提供有关对象的信息,并提供定位这些对象所需的搜索工具。有许多命名和目录服务实现,并且到它们的接口是不同的。

    Java 命名和目录接口或 JNDI 提供了一个用于访问不同的命名和目录服务的公共接口。请参阅 URL java.sun.com/products/jndi/serviceproviders.html 以获取支持通过 JNDI 接口访问命名和目录服务的供应商列表。 

    JNDI(Java Naming and Directory Interface)
    当你在开发企业beans时,JNDI很重要,因为对一个EJB的访问是通过JNDI的命名服务完成的。运用一个命名服务来查找与一个特定名字相关的一个对象。在EJB context中,一个命名服务找到一个企业bean,给定这个bean的名字。因此,了解JNDI在开发一个EJB应用程序中是至关重要的。另外,JDBC可以用JNDI来访问一个关系数据库。
    以下的一个例子是演示一个从File System Lookup.


    package study.jndi;

    import java.util.Hashtable;
    import javax.naming.Context;
    import javax.naming.InitialContext;
    import javax.naming.NamingException;

    public class Lookup{
    public static void main(String[] args){
    Hashtable env = new Hashtable();
    String name = "C:/aaa.txt";
    try{
    env.put(Context.INITIAL_CONTEXT_FACTORY,"com.sun.jndi.fscontext.RefFSContextFactory"); //use the file system as service provider
    Context ctx = new InitialContext(env);
    Object obj = ctx.lookup(name);
    System.out.println("the name " + name + " is bound to object:" + obj);
    }catch(Exception ex){
    ex.printStackTrace();
    }


    }
    }


    为了运行的程序你要到http://java.sun.com/products/jndi/downloads/index.html下载JNDI的相关包,然后把两个jar:fscontext.jar和providerutil.jar加入到你的CLASSPATH中.这样就可以运行了.你可以做进一步的操纵如bind,unbind等等.
    Context ctx = new InitialContext();是以文件系统为初始上下文,这样一来你可以把String name = "C:/aaa.txt";换成你系统中的任意目录和文件的路径名.
    env.put(Context.INITIAL_CONTEXT_FACTORY,"com.sun.jndi.fscontext.RefFSContextFactory");是指明Service provider是文件系统.
    以下的几个例子演示从LDAP上查询ENTRY并得到属性和属性值.
    假设我的LDAP是这样存放的:  根节点c=com 二级节点 ou=t 以及其它 三级节点 ou = xc 以及其它 四级节点 cn=bsj. LDAP服务器安装在我自己的机器上。
    下面的一个例子是找到一个entry(object/节点,一个意思).然后取出所有的属性值。


    package study.jndi;

    import java.util.Hashtable;
    import javax.naming.Context;
    import javax.naming.NamingException;
    import javax.naming.NamingEnumeration;
    import javax.naming.directory.DirContext;
    import javax.naming.directory.Attribute;
    import javax.naming.directory.Attributes;
    import javax.naming.directory.InitialDirContext;


    public class GetAttr{
    public static final String ENTRY_NAME = "cn=bsj,ou=xc,ou=t,c=com";
    public static void main(String[] args){

    Hashtable env = new Hashtable();
    env.put(Context.INITIAL_CONTEXT_FACTORY,"com.sun.jndi.ldap.LdapCtxFactory");
    env.put(Context.PROVIDER_URL,"ldap://127.0.0.1:10389/"); //login the ldap server
    try{
    DirContext ctx = new InitialDirContext(env);
    Attributes allAttr = ctx.getAttributes(ENTRY_NAME); //get *a* object's all attributes
    for(NamingEnumeration attrs = allAttr.getAll();attrs.hasMore();){
    Attribute attr = (Attribute)attrs.next();
    System.out.println("Attribute is : " + attr.getID());
    for(NamingEnumeration values = attr.getAll();values.hasMore();){
    System.out.println("    value is : " + values.next());
    }
    }

    }catch(NamingException ex){
    ex.printStackTrace();
    }
    System.out.println("SUCCESS!");
    }
    }


    这个例子需要到同样的地址下载ldap.jar然后加入到CLASSPATH中,就可以执行,当然要保证你有一个配置到的LDAP服务器,我的是公司专用的服务器并且是配置好的,所以你要去找一个LDAP服务器安装好在运行这个例子。这个例子的原理就是用ctx根据节点的DN(专有名词,可以看做是文件名)来查找这个entry的所有属性,然后在从属性中得到所有的值,注意一个属性可以有多个值,如果你熟悉LDAP就会知道了。
    下边这个例子在以上的例子基础上加了一个设置entry返回的属性都有哪些。


    package study.jndi;

    import java.util.Hashtable;
    import javax.naming.Context;
    import javax.naming.NamingException;
    import javax.naming.NamingEnumeration;
    import javax.naming.directory.DirContext;
    import javax.naming.directory.InitialDirContext;
    import javax.naming.directory.Attribute;
    import javax.naming.directory.Attributes;
    public class GetAttr2{
    public static final String ENTRY_NAME = "cn=bsj,ou=xc,ou=t,c=com";
    public static void main(String[] args){
    Hashtable env = new Hashtable();
    env.put(Context.INITIAL_CONTEXT_FACTORY,"com.sun.jndi.ldap.LdapCtxFactory");
    env.put(Context.PROVIDER_URL,"ldap://127.0.0.1:10389/"); //login the ldap server
    String[] attrNames = new String[]{"abc"};  //get a attribute's value
    try{
    DirContext ctx = new InitialDirContext(env);
    Attributes attrs = ctx.getAttributes(ENTRY_NAME,attrNames);
    for(NamingEnumeration ae = attrs.getAll();ae.hasMore();){
    Attribute attr = (Attribute)ae.next();
    System.out.println("Attribute : " + attr.getID());
    for(NamingEnumeration ve = attr.getAll();ve.hasMore();){
    System.out.println("  Value : " + ve.next());
    }
    }
    }catch(NamingException ex){
    ex.printStackTrace();
    }
    System.out.println("SUCCESS!");
    }
    }




     镖师甲 回复于:2004-09-30 20:05:55

    下面的例子是利用DirContext提供的search方法对entry进行查找。
    这个是查找一个CONTEXT下符合条件的一个或多个节点。


    package study.jndi;

    import java.util.Hashtable;
    import javax.naming.Context;
    import javax.naming.NamingException;
    import javax.naming.NamingEnumeration;
    import javax.naming.directory.Attribute;
    import javax.naming.directory.Attributes;
    import javax.naming.directory.BasicAttribute;
    import javax.naming.directory.BasicAttributes;
    import javax.naming.directory.DirContext;
    import javax.naming.directory.InitialDirContext;
    import javax.naming.directory.SearchResult;


    public class BasicSearch{
    public static final String ROOT_ENTRY = "ou=xc,ou=t,c=com";
    public static void main(String[] args){
    Hashtable env = new Hashtable();
    env.put(Context.INITIAL_CONTEXT_FACTORY,"com.sun.jndi.ldap.LdapCtxFactory");
    env.put(Context.PROVIDER_URL,"ldap://127.0.0.1:10389/");
    try{
    DirContext ctx = new InitialDirContext(env);
    Attributes matchAttrs = new BasicAttributes(true);//the attributes is interface
    matchAttrs.put(new BasicAttribute("cn","txc"));
    matchAttrs.put(new BasicAttribute("objectClass","top"));
    NamingEnumeration se = ctx.search(ROOT_ENTRY,matchAttrs);
    while(se.hasMore()){
    SearchResult searchResult = (SearchResult)se.next();
    System.out.println("**SearchResult : " + searchResult.getName());
    JNDITools.listAttributes(searchResult.getAttributes());
    }
    }catch(NamingException ex){
    ex.printStackTrace();
    }
    System.out.println("SUCCESS!");
    }
    }
    下面这个例子是应该是最常用的查询操作的例子用到了DirContext的几个search方法中的一个。 

    package study.jndi;

    import java.util.Hashtable;
    import javax.naming.Context;
    import javax.naming.NamingException;
    import javax.naming.NamingEnumeration;
    import javax.naming.directory.DirContext;
    import javax.naming.directory.InitialDirContext;
    import javax.naming.directory.SearchResult;
    import javax.naming.directory.SearchControls;

    public class FilterSearch{
            public static final String ROOT_ENTRY = "ou=xc,ou=t,c=com";
            public static void main(String[] args){
    Hashtable env = new Hashtable();
    env.put(Context.INITIAL_CONTEXT_FACTORY,"com.sun.jndi.ldap.LdapCtxFactory");    
    env.put(Context.PROVIDER_URL,"ldap://127.0.0.1:10389/");                                    
    try{
    DirContext ctx = new InitialDirContext(env);
    SearchControls controls = new SearchControls();
    String filter = "(&(objectClass=top)(cn=*))";

    /**
     * OBJECT_SCOPE
     *controls.setSearchScope(SearchControls.OBJECT_SCOPE);
     *NamingEnumeration se = ctx.search("cn=txc,ou=xc,ou=t,c=com",filter,controls);
    */
    controls.setCountLimit(100); //If the program attempts to get more than the count limit number of results, then a SizeLimitExceededException will be thrown 
    controls.setSearchScope(SearchControls.SUBTREE_SCOPE);
    NamingEnumeration se = ctx.search("c=com",filter,controls);
    while(se.hasMore()){
    SearchResult result = (SearchResult)se.next();
    System.out.println("**SearchResult : " + result.getName());
    JNDITools.listAttributes(result.getAttributes());
    }
    }catch(NamingException ex){
    ex.printStackTrace();
    }
                    System.out.println("SUCCESS!");
            }
    }

    下面对以上的代码进行解释:search()方法的第一个参数是一个上下文执行时在这个上下文下进行查找,第二个参数是一个Filter字串意思是符合objectClass=top并且cn属性为任意值的entry,第三个属性是一个SearchControls对象在这个对象中设置一些参数用于控制查找,如controls.setSearchScope(SearchControls.SUBTREE_SCOPE);这个方法中有三个值,SUBTREE_SCOPE为查找给定上下文(第一个参数)下以及所有下级上下文下的所有entry,而ONELEVEL_SCOPE只查找给定上下文下的entry,OBJECT_SCOPE只查找一个entry。controls.setCountLimit(100); 是设置查找返回的最大结果,如果查询的结果超过了这个值那么就会抛出一个异常。还有一个设置超时时间的方法setTimeout()。
    对了还有一个工具类用于打印给定属性集合中的所有属性以及属性的值代码如下:

    package study.jndi;

    import javax.naming.NamingException;
    import javax.naming.NamingEnumeration;
    import javax.naming.directory.Attribute;
    import javax.naming.directory.Attributes;
    public class JNDITools{
    public static void listAttributes(Attributes attrs)throws NamingException{
    for(NamingEnumeration ae = attrs.getAll();ae.hasMore();){
    Attribute attr = (Attribute)ae.next();
    System.out.println("Attribute : " + attr.getID());
    for(NamingEnumeration ve = attr.getAll();ve.hasMore();){
    System.out.println("  value : " + ve.next());
    }
    }
    }
    }
    参考资料:JNDI Toturial http://java.sun.com/products/jndi/tutorial/

    发表于 @ 2006年08月16日 12:04:00 | 评论( loading... ) | 编辑| 举报| 收藏

    新一篇:J2EE类装入过程

    • 发表评论
    • 评论内容:
    •  
    Copyright © deepass_high
    Powered by CSDN Blog