import javax.naming.*; import javax.naming.directory.*; import java.util.Hashtable; /** * Demonstrates how to perform a search and limit the time * that the search takes. * * usage: java SearchTimeLimit */ class SearchTimeLimit { static int timeout = 1000; // 1 second == 1000 ms public static void printSearchEnumeration(NamingEnumeration srhEnum) { int count = 0; try { while (srhEnum.hasMore()) { SearchResult sr = (SearchResult) srhEnum.next(); System.out.println(">>>" + sr.getName()); ++count; } System.out.println("number of answers: " + count); } catch (TimeLimitExceededException e) { System.out.println("search took more than " + timeout +"ms"); } catch (NamingException e) { e.printStackTrace(); } } public static void main(String[] args) { // Set up the environment for creating the initial context Hashtable env = new Hashtable(11); env.put(Context.INITIAL_CONTEXT_FACTORY, "com.sun.jndi.ldap.LdapCtxFactory"); env.put(Context.PROVIDER_URL, "ldap://localhost:389/o=JNDITutorial"); try { // Create initial context DirContext ctx = new InitialDirContext(env); // Set search controls to limit count to 'timeout' SearchControls ctls = new SearchControls(); ctls.setSearchScope(SearchControls.SUBTREE_SCOPE); ctls.setTimeLimit(timeout); // // Search for objects with those matching attributes NamingEnumeration answer = ctx.search("","(objectclass=*)", ctls ); // Print the answer printSearchEnumeration(answer); // Close the context when we're done ctx.close(); } catch (TimeLimitExceededException e) { System.out.println("time limit exceeded"); } catch (Exception e) { System.err.println(e); } } }