在LDAP中实现超时

时间:2014-05-27 10:59:49

标签: java spring ldap spring-ldap ldapconnection

我一直在处理我们使用 LDAP 来获取用户详细信息的应用程序。有时需要更多时间来获取用户详细信息。我想在获取详细信息的方法上实现超时,这样我们就可以避免在最坏的情况下在服务器中挂起事务。

我们在这里使用LdapUtil类,我们在其中配置LdapTemplate类来获取所需的详细信息。

我们如何在LDAP方法上实现超时? (在这种情况下为ldapTemplate.search(...)方法)

public class LdapUtil {

    @Autowired(required = true)
    @Qualifier(value = "ldapTemplateApp")
    LdapTemplate ldapTemplate;

    public Set < ProductGroup > findProducts(String UserId) {
        final Set < ProductGroup > products = newHashSet();
        // Lookup the user         
        String usrFilter = String.format(USERID_FILTER, globalUserId);

        ldapTemplate.search("ou=Members", usrFilter, // note this line
        new NameClassPairCallbackHandler() {

            public void handleNameClassPair(NameClassPair nameClassPair) {
                SearchResult result = (SearchResult) nameClassPair;
                String user = result.getNameInNamespace();

                String GrpFilter = String.format(GROUP_FILTER, user);

                List < String > zonePrefixes = ldapTemplate.search("Zones", GrpFilter, // note this line
                new AttributesMapper() {
                    public Object mapFromAttributes(Attributes attributes) throws NamingException {
                        return substringBeforeLast((String) attributes.get("cn").get(), "-") + "-";
                    }
                });

            }
        });

        products.remove(null);
        return newHashSet(products);
    }
}   

我们有一个 LDAP.xml ,其中配置了ldapTemplete

<beans xmlns="------">
<!-- LDAP -->
<bean id="contextSourceApp" class="org.springframework.ldap.pool.factory.PoolingContextSource">
<property name="contextSource" ref="contextSourceTargetApp" />
<property name="dirContextValidator">
<bean id="dirContextValidator"   
class="org.springframework.ldap.pool.validation.DefaultDirContextValidator"/>
</property>         
<property name="testOnBorrow" value="true" />
</bean>
<bean id="contextSourceTargetApp" class="org.springframework.ldap.core.support.LdapContextSource">
    <property name="url" value="${ldap.url}" />
    <property name="base" value="${ldap.base.}" />
    <property name="userDn" value="${ldap.user}" />
    <property name="password" value="${ldap.password}" />
    <property name="pooled" value="false" />
</bean>

<bean id="ldapTemplateApp" class="org.springframework.ldap.core.LdapTemplate">
    <constructor-arg ref="contextSourceApp" />
</bean>

我几乎没有疑问:

  1. 我们如何实现LDAP方法的TIMEOUT以及如何配置它?(在哪种类型的LDAP框架超时设置中)

  2. 有没有办法在xml文件中配置它们,即LDAP.xml(在这种情况下)?

2 个答案:

答案 0 :(得分:8)

我找到了解决方案。 我在ldap.xml文件中添加了以下属性。到目前为止它对我有用。

<bean id="contextSourceTargetApp" 
      class="org.springframework.ldap.core.support.LdapContextSource">
    <property name="baseEnvironmentProperties">
        <map>
            <entry key="com.sun.jndi.ldap.connect.timeout" value="5000" />          
        </map>  
    </property>
</bean>

如果您对LDAP超时实施有任何了解,请发布任何其他解决方案。

答案 1 :(得分:2)

对于ActiveDirectoryLdapAuthenticationProvider,使用ldap.xml文件的解决方案对我不起作用。相反,我在类路径中添加了jndi.properties文件,其中包含以下内容:

com.sun.jndi.ldap.connect.timeout=500