- 論壇徽章:
- 0
|
求助:老大們能否給個(gè)Jsp連接LDAP服務(wù)器讀寫(xiě)數(shù)據(jù)的例子。
既然找到了,轉(zhuǎn)貼一個(gè)給大家看看:
下面四個(gè)JAVA方法,分別用于初始化,查詢(xún),添加,刪除,修改,關(guān)閉連接。
記得每次都需要先大概連接,操作,然后關(guān)閉連接。和使用數(shù)據(jù)庫(kù)差不多。
首先是需要用到的頭文件:
import java.util.Hashtable;
import java.util.Enumeration;
import javax.naming.Context;
import javax.naming.NamingException;
import javax.naming.directory.DirContext;
import javax.naming.directory.InitialDirContext;
import javax.naming.directory.SearchControls ;
import javax.naming.NamingEnumeration;
import javax.naming.directory.SearchResult;
import javax.naming.directory.Attributes ;
import javax.naming.directory.Attribute;
import javax.naming.directory.BasicAttributes;
import javax.naming.directory.BasicAttribute;
import javax.naming.directory.ModificationItem;
import java.lang.reflect.Method;
import java.io.BufferedReader;
import java.io.InputStreamReader;
然后是一個(gè)類(lèi)域,用于保存上下文:
DirContext ctx = null;
然后是初始化:
public void init(){
String account="Admin";//操作LDAP的帳戶(hù)。默認(rèn)就是Admin。
String password="weblogic";//帳戶(hù)Admin的密碼。
String root="dc=ldapdomain"; //所操作的WLS域。也就是LDAP的根節(jié)點(diǎn)的DC
Hashtable env = new Hashtable();
env.put(Context.INITIAL_CONTEXT_FACTORY, "com.sun.jndi.ldap.LdapCtxFactory" ;//必須這樣寫(xiě),無(wú)論用什么LDAP服務(wù)器。
env.put(Context.PROVIDER_URL, "ldap://localhost:7001/" + root);//LDAP服務(wù)器的地址:端口。對(duì)WLS端口就是7001
env.put(Context.SECURITY_AUTHENTICATION, "none" ;//授權(quán)界別,可以有三種授權(quán)級(jí)別,但是如果設(shè)為另外兩種都無(wú)法登錄,我也不知道為啥,但是只能設(shè)成這個(gè)值"none"。
env.put(Context.SECURITY_PRINCIPAL, "cn=" + account + "," + root);//載入登陸帳戶(hù)和登錄密碼
env.put(Context.SECURITY_CREDENTIALS, password);
try{
ctx = new InitialDirContext(env);//初始化上下文
System.out.println("認(rèn)證成功" ;//這里可以改成異常拋出。
}catch(javax.naming.AuthenticationException e){
System.out.println("認(rèn)證失敗" ;
}catch(Exception e){
System.out.println("認(rèn)證出錯(cuò):"+e);
}
}
查詢(xún)操作:
public void search(){//我只能按照某些屬性查找節(jié)點(diǎn),偶還不會(huì)怎么查找一個(gè)目錄或按照更復(fù)雜的正則式查找特定節(jié)點(diǎn)/目錄
try{
SearchControls constraints = new SearchControls();
constraints.setSearchScope(SearchControls.SUBTREE_SCOPE);
System.out.print("what would you want to search:" ;
BufferedReader bd=new BufferedReader(new InputStreamReader(System.in));
String s=bd.readLine();
NamingEnumeration en = ctx.search("", "uid="+s, constraints); //要查詢(xún)的UID。如果是*則可以查到所有UID的節(jié)點(diǎn)
if(en == null){
System.out.println("Have no NamingEnumeration." ;
}
if(!en.hasMoreElements()){
System.out.println("Have no element." ;
}
while (en != null && en.hasMoreElements()){//可以查出多個(gè)元素
Object obj = en.nextElement();
if(obj instanceof SearchResult){
SearchResult si = (SearchResult) obj;
System.out.println(" name: " + si.getName());
Attributes attrs = si.getAttributes();
if (attrs == null){
System.out.println(" No attributes" ;
}else{
for (NamingEnumeration ae = attrs.getAll(); ae.hasMoreElements() {//獲得該節(jié)點(diǎn)的所有屬性
Attribute attr = (Attribute) ae.next();//下一屬性
String attrId = attr.getID();//獲得該屬性的屬性名
for (Enumeration vals = attr.getAll();vals.hasMoreElements() {//獲得一個(gè)屬性中的所有屬性值
System.out.print(" "+attrId + ": ");
Object o = vals.nextElement();//下一屬性值
if(o instanceof byte[])
System.out.println(new String((byte[])o));
else
System.out.println(o);
}
}
}
}
else{
System.out.println(obj);
}
System.out.println();
}
}catch(Exception e){
System.out.println("Exception in search():"+e);
}
}
添加操作:
public void add(){
try{
String newUserName = "stella";
BasicAttributes attrs = new BasicAttributes();
BasicAttribute objclassSet = new BasicAttribute("objectclass");
objclassSet.add("person");
objclassSet.add("top");
objclassSet.add("organizationalPerson");
objclassSet.add("inetOrgPerson");
objclassSet.add("wlsUser");
attrs.put(objclassSet);
attrs.put("sn", newUserName);
attrs.put("uid", newUserName);
attrs.put("cn", newUserName);
ctx.createSubcontext("uid=" + newUserName+",ou=people,ou=myrealm", attrs); //添加一個(gè)節(jié)點(diǎn),我還不會(huì)添加目錄
}catch(Exception e){
System.out.println("Exception in add():"+e);
}
}
修改操作:
public void edit(){
try{
String account = "stella";//修改以前舊的值
String sn = "stella sn";//修改以后新的值
ModificationItem modificationItem[] = new ModificationItem[1];
modificationItem[0] =
new ModificationItem(
DirContext.REPLACE_ATTRIBUTE,new BasicAttribute("sn", sn));//所修改的屬性
ctx.modifyAttributes("uid=" + account, modificationItem); //執(zhí)行修改操作
}catch(Exception e){
System.out.println("Exception in edit():"+e);
}
}
刪除節(jié)點(diǎn)操作:
public void delete(){
try{
String uid = "stella";
String dc = "dc=it,dc=com";
ctx.destroySubcontext("uid=" + uid); //按照UID刪除某個(gè)節(jié)點(diǎn)。我還不會(huì)刪除一個(gè)目錄。
}catch(Exception e){
System.out.println("Exception in edit():"+e);
}
}
關(guān)閉連接:
public void close(){
if(ctx != null)
{
try
{
ctx.close();
}
catch (NamingException e)
{
System.out.println("NamingException in close():"+e);
}
}
}
我對(duì)LDAP的理解:它是用于對(duì)資源的管理和服務(wù)的訪(fǎng)問(wèn)協(xié)議,在Weblogic平臺(tái)上的JNDI(包含EJB和DataSource)都是提供它來(lái)提供的。
正是JNDI的服務(wù)和RMI結(jié)合就形成J2EE平臺(tái)上分布式的應(yīng)用,因此說(shuō)到底層,還是LDAP協(xié)議的支持。 |
|