📄 jndiadd.java
字号:
//package jndi;/*曾海 2003/9 JNDI程序将一个标准的ldap数据格式放进ldap服务器。*/import java.util.*;// hashtableimport javax.naming.*;//命名服务import javax.naming.directory.*;//初始化上下文用import javax.swing.JOptionPane;/*在服务上准备:uid=ZHai,ou=Groups,dc=jssvc,dc=com记录。密码设成916,如果不会请看讲义准备加入person类。它实现Initialcontext故此能加入*/public class JNDIAdd { public static String sunLdapContext="com.sun.jndi.ldap.LdapCtxFactory"; public static String hostURL="ldap://127.0.0.1:389";//这个端口取决于你安装时的选择。 public static String searchBase= "dc=jssvc, dc=com";//从默认的点开始寻找,这里的根是dc-dc public static String searchContents="(uid=*)";//sn=surname名字(sn=zeng)也可以,大家可以试试sn=*可以任意匹配 //public static String dn="uid=ZHai,ou=Groups,dc=jssvc,dc=com"; public static String dn="cn=portal"; public static String pw="secret"; public JNDIAdd() { DirContext ctx=null; try{ Hashtable env = new Hashtable();//准备放属性 env.put(Context.INITIAL_CONTEXT_FACTORY ,sunLdapContext); env.put(Context.PROVIDER_URL ,hostURL); env.put(Context.SECURITY_AUTHENTICATION ,"simple"); env.put(Context.SECURITY_PRINCIPAL ,dn); env.put(Context.SECURITY_CREDENTIALS,pw); SearchControls constraints = new SearchControls();//这个类在naming.directory里的,用于确定搜索的范围,是全局,一层还是下一层,请看我的备课笔记 constraints.setSearchScope(SearchControls.SUBTREE_SCOPE ) ;//搜索全部的目录树 ctx = new InitialDirContext(env);//这句会有意外,好好捉吧 }catch (Exception e){ System.err.println("错误,连接不上服务器,可能是密码不对劲儿") ; System.exit(1);}; System.err.println("非常好,连接上了"); try{ Person p = new Person("213"); //ctx.bind("uid=Sam,ou=Groups,o=jssvc.com ",p); // ctx.bind( "cn=SGamgee , ou=Groups,dc=jssvc,dc=com",p); ctx.bind("uid=yang123,obj=user,cn=portal",p); }catch(NamingException ne){ ne.printStackTrace() ;System.exit(1);}; } public static void main(String[] args) { JNDIAdd JNDIAdd1 = new JNDIAdd(); System.exit(0); }}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -