如何使用Java操作LDAP之检索条目(二)

本篇文章为大家介绍一下如何在LDAP下检索条目,你可以把这个操作想象成查询数据库里的记录。由于LDAP的数据存储是一个树形结构,所以一般的检索都是为了检索出某个条目有哪些下级条目。

 

1、为了程序更健壮,我先给出一个判断条目是否存在的函数:
//判断条目是否已存在
static public boolean IsExist(String ldappath)
{
   DirContext ctx = null;          //这是LDAP的连接对象,上篇文章中已经介绍过
   ctx = GetConnection();     //GetConnection其实就是用上篇文章中的代码所写的一个函数
   try
   {
    ctx.search(ldappath, null);   //测试检索一下
    return true;                          //表示这个条目是存在的
   }
   catch(NamingException ex)
   {
         return false;    
 
}

2、检索某条目的下级条目

//检索条目的下级条目
//ldappath 本级条目路径,如:dc=cs,dc=hunan,dc=com
//attrname 用于过滤的属性名,即条目包含该属性,可为空串
//attrval     用于过滤的属性值,即上面的属性包含该属性值,可为空串
//注意,当attrname为空串时,将忽略attrval
//这个函数会返回NamingEnumeration对象,通过这个对象,我们可以遍历出所有搜索到的结果
static public NamingEnumeration<Object> SearchSubEntry(String ldappath,String attrname,String attrval)
{
   NamingEnumeration ret = null;   
   DirContext ctx = null;
   ctx = GetConnection();    //取连接对象
   if(ctx != null)
   {  
    try
    {
     if(IsExist(ldappath)) //先判断一下这个条目是不是存在
     {
      //设定搜索条件     
      Attributes matchAttrs = new BasicAttributes(true);    //建一个属性集合对象
      if(attrname.compareTo("") != 0)                       //如果传入了属性名称条件就加到属性集合里
             matchAttrs.put(new BasicAttribute(attrname, attrval));
      //搜索符合条件的结果
      NamingEnumeration answer = ctx.search(ldappath, matchAttrs);
      ret = answer;
     }
    }
    catch(NamingException ex)
      {
       ret = null;    //出现异常时会返回null
         ex.printStackTrace();
      }    
   }
   return ret;    
}

3、将上面函数的返回对象转成一个ArrayList,这样感觉更好使用,如下:

ArrayList<String> mylist= new ArrayList<String>();
NamingEnumeration<Object> sret = null;  
sret = SearchSubEntry("dc=cs,dc=hunan,dc=com","","");
while (sret.hasMore())
{
      SearchResult sr = (SearchResult) sret.next();
      mylist.add(sr.getName());
}

这样,得到的mylist就是一个包含检索结果的字符串集合,每一项就是一个子条目的名称。


转载自:http://blog.sina.com.cn/s/blog_4da69d9a0100ja76.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值