我在对我们公司的 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=Personal,ou=FOO,o=FOO,dc=foo,dc=com' )
{
$mesg = $ldap->search( base => "o=FOO,dc=foo,dc=com", filter => $filter );
print Dumper($mesg), "\n\n";
}
虽然前两个过滤器有效(如返回预期值),但最后一个复杂的过滤器无效。它返回一个空数组。真正让我感到困惑的是,当我将它与像 Softerra LDAP 浏览器这样的工具一起使用时,完全相同的查询字符串会起作用。
我也尝试过使用 PHP 的ldap_search
& co 进行相同的查询,但无济于事。
有人可以对此有所了解吗?
谢谢阅读
霍利
编辑:这是服务器的结构:
Server
ou=FOO
ou=...
ou=Personal
uid=something
我需要一个 uid 列表。