加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 大数据 > 正文

如何使用Perl的Net :: LDAP进行复杂查询?

发布时间:2020-12-15 21:47:29 所属栏目:大数据 来源:网络整理
导读:我在针对公司LDAP服务器运行复杂查询时遇到问题.我正在使用以下Perl脚本: use Data::Dumper;use Net::LDAP;die "Can't connect to LDAP-Server: $@n" unless $ldap = Net::LDAP-new( 'xLDAPx' );foreach my $filter ( 'ou=Personal','ou=BAR','ou=Personal
我在针对公司LDAP服务器运行复杂查询时遇到问题.我正在使用以下Perl脚本:
use Data::Dumper;
use Net::LDAP;

die "Can't connect to LDAP-Server: $@n" 
    unless $ldap = Net::LDAP->new( 'xLDAPx' );


foreach my $filter ( 'ou=Personal','ou=BAR','ou=Personal,ou=BAR',ou=FOO,o=FOO,dc=foo,dc=com' )
{ 
    $mesg = $ldap->search( base => "o=FOO,dc=com",filter => $filter );
    print Dumper($mesg),"nn";
}

虽然前两个过滤器起作用(如返回预期值),但最后一个过滤器不起作用.它返回一个空数组.让我感到困惑的是,当我使用像Softerra LDAP Browser这样的工具时,完全相同的查询字符串可以正常工作.

我也尝试使用PHP的ldap_search&合作,无济于事.

有人可以对此有所了解吗?

谢谢阅读

holli

编辑:
这是服务器的结构:

Server
    ou=FOO
        ou=...
        ou=Personal
            uid=something

我需要一份uid列表.

解决方法

我想你希望它更像(&(ou =个人)(ou = FOO)(o = FOO)(dc = foo)(dc = com)).
但是你根本不清楚你想要什么,所以我不能为你做过滤器.

编辑补充:我猜这是你想做的事:( |(ou = Personal)(ou = FOO))

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读