openfire使用ldap认证,组的过滤设置

正常配置openfire使用ldap认证后,在openfire后台可以看到所有用户和组,但是组里面没有用户。

解决方法:

一、增加member属性到organizationalUnit这个objectclass中

编辑core.schema

这个schema中有member这个attribute,但是organizationalUnit objectclass中没有启用,所以在:

objectclass ( 2.5.6.5 NAME 'organizationalUnit'

DESC 'RFC2256: an organizational unit'

SUP top STRUCTURAL

MUST ou

MAY ( userPassword $ searchGuide $ seeAlso $ businessCategory $

x121Address $ registeredAddress $ destinationIndicator $

preferredDeliveryMethod $ telexNumber $ teletexTerminalIdentifier $

telephoneNumber $ internationaliSDNNumber $

facsimileTelephoneNumber $ street $ postOfficeBox $ postalCode $

postalAddress $ physicalDeliveryOfficeName $ st $ l $ description $ member ) )

中增加$ member,重启ldap即可。


二、修改openfire.script脚本:

编辑/opt/openfire/embedded-db/openfire.script文件,修改如下行为:

INSERT INTO OFPROPERTY VALUES('ldap.groupMemberField','seeAlso')

INSERT INTO OFPROPERTY VALUES('ldap.groupMemberField','member')


三、添加组员到组中。

这样在ldapadmin后台OU里面添加新的attribute的时候就可以看到member这个属性了。member的值如下图所示:

151621267.png


这样,重启openfire和ldap后,登陆spark就可以看到组已经组员了。


备注一下:

属性名属性值编辑删除
admin.authorizedJIDs
单击可编辑此属性单击可删除此属性
ldap.adminDN
cn=root,dc=domain,dc=com
单击可编辑此属性单击可删除此属性
ldap.adminPassword
hidden
单击可编辑此属性单击可删除此属性
ldap.autoFollowAliasReferrals
true
单击可编辑此属性单击可删除此属性
ldap.autoFollowReferrals
false
单击可编辑此属性单击可删除此属性
ldap.baseDN
dc=domain,dc=com
单击可编辑此属性单击可删除此属性
ldap.connectionPoolEnabled
true
单击可编辑此属性单击可删除此属性
ldap.debugEnabled
false
单击可编辑此属性单击可删除此属性
ldap.emailField
mail
单击可编辑此属性单击可删除此属性
ldap.encloseDNs
true
单击可编辑此属性单击可删除此属性
ldap.groupDescriptionField
description
单击可编辑此属性单击可删除此属性
ldap.groupMemberField
member
单击可编辑此属性单击可删除此属性
ldap.groupNameField
ou
单击可编辑此属性单击可删除此属性
ldap.groupSearchFilter
(&(ou={0})(objectClass=organizationalUnit))
单击可编辑此属性单击可删除此属性
ldap.host
10.0.0.12
单击可编辑此属性单击可删除此属性
ldap.ldapDebugEnabled
false
单击可编辑此属性单击可删除此属性
ldap.nameField
description
单击可编辑此属性单击可删除此属性
ldap.override.avatar
true
单击可编辑此属性单击可删除此属性
ldap.port
389
单击可编辑此属性单击可删除此属性
ldap.posixMode
false
单击可编辑此属性单击可删除此属性
ldap.searchFields

单击可编辑此属性单击可删除此属性
ldap.searchFilter
(&(cn={0})(objectClass=inetOrgPerson))
单击可编辑此属性单击可删除此属性
ldap.sslEnabled
false
单击可编辑此属性单击可删除此属性
ldap.usernameField
cn
单击可编辑此属性单击可删除此属性
ldap.vcard-mapping
<span title="<![CDATA[<br><vCard xmlns=" vcard-temp"><N>
<GIVEN>{description}</GIVEN>
</N>
<EMAIL>
<INTERNET/>
<USERID>{mail}</USERID>
</EMAIL>
<FN>{description}</FN>
<NICKNAME>{uid}</NICKNAME>
<ADR>
<HOME/>
</ADR>
<ADR>
<WORK/>
</ADR>
</vCard>]]>"><![CDATA[
<vCard xmlns="vcard-temp">
<N>
<GIVEN>{description}</GIVEN>
</N>
<EMAIL>
<INTERNET/>
<USERID>{mail}</USERID>
</EMAIL>
<FN>{description}</FN>
<NICKNAME>{uid}</NICKNAME>
<ADR>
<HOME/>
</ADR>
<ADR>
<WORK/>
</ADR>
</vCard>]]>
单击可编辑此属性单击可删除此属性
provider.auth.className
org.jivesoftware.openfire.ldap.LdapAuthProvider
单击可编辑此属性单击可删除此属性
provider.group.className
org.jivesoftware.openfire.ldap.LdapGroupProvider
单击可编辑此属性单击可删除此属性
provider.user.className
org.jivesoftware.openfire.ldap.LdapUserProvider
单击可编辑此属性单击可删除此属性
provider.vcard.className
org.jivesoftware.openfire.ldap.LdapVCardProvider
单击可编辑此属性单击可删除此属性
update.lastCheck
1379953378982
单击可编辑此属性单击可删除此属性
xmpp.auth.anonymous
true
单击可编辑此属性单击可删除此属性
xmpp.domain
domain.com.cn
单击可编辑此属性单击可删除此属性
xmpp.session.conflict-limit
0
单击可编辑此属性单击可删除此属性
xmpp.socket.ssl.active
true
单击可编辑此属性单击可删除此属性


这是一个介绍关于ldap group的连接:http://www.zytrax.com/books/ldap/ch11/groups.html

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章