7

我可以成功绑定到 AD LDAP,并修改和创建对象。

但是,如果我想更新或设置“布尔”类型的属性,则会收到以下错误:

00000057:LdapErr:DSID-0C090C3E,注释:属性转换操作出错,数据0,v1db1

这是一段负责的 Perl 代码:

$rv = $ldap->add($dn, attr=> [
    cn => [$u],
    objectClass => [ 'top','person', 'organizationalPerson', 'contact' ],
    displayName => "$u Mailing List",
    mail => $email,
    name => $u,
    mailNickname => $local,
    proxyAddresses => [
        "SMTP:$email",
        "smtp:$local\@$SERVERDOM",
    ],
    givenName => $u,
    targetAddress => "SMTP:$email",
    internetEncoding => 1310720,
    msExchAddressBookFlags => 1,
    msExchModerationFlags => 6,
    msExchProvisioningFlags => 0,
        msExchHideFromAddressList => 'TRUE',
        msExchBypassAudit => 'FALSE',
        msExchMailboxAuditEnable => 'FALSE',

]);

问题是最后三个属性;如果它们被注释掉,那么它就可以工作。我尝试使用 0 和 1 而不是 'TRUE' 和 'FALSE' 但我遇到了同样的问题。似乎Net::LDAP代码调用Convert::ASN1类型为stringorint不正确;它应该使用“布尔”,但我看不出如何让它做到这一点。

4

1 回答 1

5

根据 LDAP 规范;“TRUE”、“True”、“true”等字符串值均有效。

未知属性或该用户不可用的属性将引发“属性转换操作错误”错误。

查看属性并在谷歌上搜索它们表明msExchHideFromAddressList应该是msExchHideFromAddressLists<- 注意复数 s。

于 2014-12-04T05:31:37.383 回答