You are viewing a plain text version of this content. The canonical link for it is here.
Posted to dev@directory.apache.org by "Alex Karasulu (JIRA)" <di...@incubator.apache.org> on 2005/09/12 01:22:36 UTC
[jira] Resolved: (DIREVE-239) Anonymous user may gain access as admin user
[ http://issues.apache.org/jira/browse/DIREVE-239?page=all ]
Alex Karasulu resolved DIREVE-239:
----------------------------------
Fix Version: 0.9.3
Resolution: Fixed
Committed in revision 280210 here:
http://svn.apache.org/viewcvs.cgi?view=rev&rev=280210
> Anonymous user may gain access as admin user
> --------------------------------------------
>
> Key: DIREVE-239
> URL: http://issues.apache.org/jira/browse/DIREVE-239
> Project: Directory Server
> Type: Bug
> Versions: 0.9.3
> Reporter: Endi S. Dewata
> Assignee: Alex Karasulu
> Priority: Blocker
> Fix For: 0.9.3
>
> Anonymous user may gain access as admin user by specifying java.naming.ldap.version=3 in the JNDI client.
> To show the problem, add a print statement in the AuthenticationService.java at line 369:
> // perform the authentication
> LdapPrincipal authorizationId = authenticator.authenticate( ctx );
> System.out.println("Authorization ID: "+authorizationId);
> Start the server, then run the following program:
> import junit.framework.TestCase;
> import javax.naming.Context;
> import javax.naming.NamingEnumeration;
> import javax.naming.directory.*;
> import java.util.Hashtable;
> public class Test extends TestCase {
> public void testAnonymousBindWithLDAPVersion3() throws Exception {
> String suffix = "dc=apache,dc=org";
> Hashtable env = new Hashtable();
> env.put(Context.INITIAL_CONTEXT_FACTORY, "com.sun.jndi.ldap.LdapCtxFactory");
> env.put(Context.PROVIDER_URL, "ldap://localhost:10389/");
> // env.put("java.naming.ldap.version", "3");
> DirContext ctx = new InitialDirContext(env);
> SearchControls sc = new SearchControls();
> sc.setSearchScope(SearchControls.SUBTREE_SCOPE);
> NamingEnumeration ne = ctx.search(suffix, "(objectClass=*)", sc);
> System.out.println("Search results:");
> int counter = 0;
> while (ne.hasMore()) {
> SearchResult sr = (SearchResult)ne.next();
> String rdn = sr.getName();
> System.out.println(" - "+("".equals(rdn) ? suffix : rdn+","+suffix));
> counter++;
> }
> System.out.println("Found "+counter+" entries.");
> ctx.close();
> }
> }
> Without specifying java.naming.ldap.version=3, the user will remain anonymous (empty Authentication ID). However, with java.naming.ldap.version=3, the anonymous user gets authenticated as the admin user without even specifying any password.
--
This message is automatically generated by JIRA.
-
If you think it was sent incorrectly contact one of the administrators:
http://issues.apache.org/jira/secure/Administrators.jspa
-
For more information on JIRA, see:
http://www.atlassian.com/software/jira