JNDI ldap使用userPrincipalName的原理是什么

satfire 2016-06-03 03:10:06
http://www.cnblogs.com/haore147/p/4806485.html

Hashtable HashEnv = new Hashtable();
String LDAP_URL = "ldap://192.168.1.***:389";
String adminName = "Administrator@***.cn";
String adminPassword = "****";
HashEnv.put(Context.SECURITY_AUTHENTICATION, "simple");
HashEnv.put(Context.SECURITY_PRINCIPAL, adminName);

而通常的用法是设置DN,JNDI是直接把userPrincipalName发给LDAP服务器的么?
有或者是怎么把userPrincipalName(即Administrator@***.cn)转化为DN(即CN=张三,CN=Users,DC=microsoft,DC=com'的?
...全文
189 2 打赏 收藏 转发到动态 举报
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
satfire 2016-06-03
  • 打赏
  • 举报
回复
public void reconnect(Control[] connCtls) throws NamingException { getDefaultLdapInitCtx().reconnect(connCtls); } 跟踪到这里,就不知道了。
satfire 2016-06-03
  • 打赏
  • 举报
回复
还有一个问题: 以下两个方法都是可以的,这个转换(兼容)是那个类做的? //String adminName = "zhangsan@it-abc.com";//username@domain //ok //String adminName = "CN=张三,CN=Users,dc=abc,dc=com";//ok env.put(Context.INITIAL_CONTEXT_FACTORY,"com.sun.jndi.ldap.LdapCtxFactory"); env.put(Context.SECURITY_AUTHENTICATION, "simple");//"none","simple","strong" env.put(Context.SECURITY_PRINCIPAL, adminName);

67,513

社区成员

发帖
与我相关
我的任务
社区描述
J2EE只是Java企业应用。我们需要一个跨J2SE/WEB/EJB的微容器,保护我们的业务核心组件(中间件),以延续它的生命力,而不是依赖J2SE/J2EE版本。
社区管理员
  • Java EE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧