异常 - 一旦ldap服务器重新启动,java访问ldap服务器

时间:2011-03-22 23:56:28

标签: ldap bea

我有下一个问题,我从LDAP设置中获取了一个上下文的UpContext的JNDI环境属性的上下文。  然后我重新启动ldap服务器,每次尝试再次获取InitialContext时,抛出下一个异常。

获取上下文的代码。

  Context ctx = null;

  Hashtable ht = new Hashtable();
  ht.put(Context.INITIAL_CONTEXT_FACTORY,
         "weblogic.jndi.WLInitialContextFactory");
  ht.put(Context.PROVIDER_URL,"t3://localhost:7001");
  ht.put(Context.SECURITY_PRINCIPAL,"USER1");
  ht.put(Context.CREDENTIALS,"PASSWORD1");
  try {
    ctx = new InitialContext(ht);
  }
  catch (NamingException e) {
  }
  finally {
    try {ctx.close();
  }
  catch (Exception e) {
      // a failure occurred
  }
  }

例外:

  java.security.PrivilegedActionException: javax.naming.ConfigurationException: Call to NamingManager.getObjectInstance() failed:
[Root exception is java.lang.SecurityException:
[Security:090398]Invalid Subject: principals=[ADMIN]]; remaining name ''
BEA-090398

1 个答案:

答案 0 :(得分:1)

您没有提供正确的DN进行身份验证:

ht.put(Context.SECURITY_PRINCIPAL,"USER1");

你应该有cn = user1,ou = something,dc = something,dc = com等。