następujący kod działał przez 3 miesiące bez żadnych problemów. Od dzisiaj otrzymuję następujący błąd; "Wyjątek został zgłoszony przez cel wywołania" i wewnętrzny wyjątek; . "Odmowa dostępu (wyjątek od HRESULT: 0x80070005 (E_ACCESSDENIED)"Dostęp do SetPassword LDAP jest zabroniony
Funkcja uwierzytelniania działa Oto moje funkcje;
public bool Authenticate(string strUserName, string strPassword)
{
bool authenticated = false;
using (
var entry = new DirectoryEntry("LDAP://myldapserver", strUserName + "@domain", strPassword,
AuthenticationTypes.Secure))
{
try
{
object nativeObject = entry.NativeObject;
authenticated = true;
}
catch (DirectoryServicesCOMException ex)
{
return false;
}
}
return authenticated;
}
i metoda ChangePassword;
public bool ChangePassword(string strUserName, string strOldPassword, string strNewPassword)
{
const long ADS_OPTION_PASSWORD_PORTNUMBER = 6;
const long ADS_OPTION_PASSWORD_METHOD = 7;
const int ADS_PASSWORD_ENCODE_REQUIRE_SSL = 0;
const int ADS_PASSWORD_ENCODE_CLEAR = 1;
string strPort = "636";
int intPort;
intPort = Int32.Parse(strPort);
try
{
string strUserString = "domain" + @"\" + strUserName.Trim();
var entry = new DirectoryEntry("LDAP://myldapserver", strUserString, strOldPassword,
AuthenticationTypes.Secure);
var search = new DirectorySearcher(entry);
string strFilter = "(SAMAccountName=" + strUserName + ")";
search.Filter = strFilter;
SearchResult result = search.FindOne();
DirectoryEntry user = result.GetDirectoryEntry();
user.Invoke("SetOption", new object[] { ADS_OPTION_PASSWORD_PORTNUMBER, intPort });
user.Invoke("SetOption", new object[] { ADS_OPTION_PASSWORD_METHOD, ADS_PASSWORD_ENCODE_CLEAR });
**user.Invoke("SetPassword", new object[] { strNewPassword });**
user.CommitChanges();
user.Close();
}
catch (Exception exception)
{
string msg = exception.InnerException.Message;
return false;
}
return true;
}
To zgłasza expcetion po wywołaniu właściwości SetPassword Każda pomoc byłaby bardzo doceniana
Która linia zawodzi? Jaka metoda zawodzi? –
ChangePassword to błąd, który kończy się niepowodzeniem na linii user.Invoke ("SetPassword", new object [] {strNewPassword}); – user1595357
Wiadomość umieszczona u góry jest wewnętrznym wyjątkiem? Pytam, ponieważ wyjątek wewnętrzny zawiera rzeczywisty otrzymany wyjątek COM. –