2017-02-23 77 views
0

我真的Active Directory中的新手....如何处理DirectoryEnter.CommitChange()异常? C#

当我检查,并约Add User And Department到Active Directory使用C#编辑应用程序,

DirectoryEnter.CommitChage()使一个例外是这样的。

The directory service cannot perform the requested operation on the RDN attribute of an object.

但是我前面提到的,我不知道还有有关Active Directory,我困惑如何处理它。

请有人帮助我。代码如下。

void CreateADUser(string ppk,string pk,DataRow row) 
{ 
    string pass = GetPass(pk,row,LogSections.AD); 
    DirectoryEntry addept = adm.FindOU(ppk); 
    string sOU = adm.GetPrincipalPath(addept); 
    var aduser = adm.CreateNewUser(sOU, pk, pass, pk, null, null, adm.sDomain); 
    SetAdUserProperties(pk, pass, row); 
    MoveUser(ppk,pk); 
} 



void SetAdUserProperties(string pk,string pass,DataRow row) 
{ 
    if (row == null) return; 
    List<ADMapping> MappingPatterns = GetAdMappings(Words.User,false); 
    var colnames = Tool.GetColNames(row); 
    var aduser = adm.GetUser(pk); 
    var de=aduser.GetUnderlyingObject() as DirectoryEntry; 
    foreach (var ADMap in MappingPatterns) 
    { 
     string val = ADMap.Mapping; 
     val=Util.ReplaceColPattern(val, row); 
     SetProperty(de, ADMap.CN, val); 
    } 
    if (!string.IsNullOrWhiteSpace(pass)) 
    { 
     var UserPkColumn = AppConfigHelper.GetAppString(Words.SourceUserPKColumn); 
     UserPkColumn = Util.GetActualColName(UserPkColumn); 
     aduser.SetPassword(pass); 
     QueryHelper.Update(QueryHelper.ConnectionString, Words.ShadowUserTable 
        ,new SqlParameter[] { new SqlParameter("@passwd", pass) } 
        , new SqlParameter("@"+UserPkColumn,pk)); 
    } 

    aduser.Save(); 
} 

public void SetProperty(DirectoryEntry oDE, string sPropertyName, object sPropertyValue) 
{ 
    if (sPropertyValue != null && !string.IsNullOrWhiteSpace(sPropertyValue.ToString())) 
    { 
     if (oDE.Properties.Contains(sPropertyName)) 
     { 
      oDE.Properties[sPropertyName].Value = sPropertyValue; 
     } 
     else 
     { 
      oDE.Properties[sPropertyName].Add(sPropertyValue); 
     } 
     try 
     { 
      oDE.CommitChanges(); //exception here. 
      oDE.Close(); 
     } 
     catch (Exception) 
     { 

     } 

    } 


    } 

回答

0

尝试做重命名前提交修改希望这将有助于

oDE.Rename("name=$name"); 
    oDE.CommitChanges(); 
+0

对不起我真的来不及看到你的答案。我添加了你的代码,但它仍然抛出异常... –