Solved

How do I reset an AD LDS account password in .NET?

Posted on 2009-04-09
1
2,349 Views
Last Modified: 2013-12-24
I need to create a web-based .NET web application for creating a new AD LDS user account and assigning a password to it.  The web-form will be hosted in IIS 7 on a different server than the AD LDS server.  Presently, my code is able to create and assign attributes to a new AD LDS user.  However, when I try to reset the password of the user, I run into an exception:

STACK TRACE:

System.Reflection.TargetInvocationException was unhandled by user code
Message="Exception has been thrown by the target of an invocation."
Source="System.DirectoryServices"
StackTrace:
at System.DirectoryServices.DirectoryEntry.Invoke(String methodName,
Object[] args)
at SierraSys.LdapAdminTool.Web.CreateUser.OnPreRender(EventArgs e) in
C:\PROJECTS\Internal\LdapAdminTool\LdapAdmin1.0\Web\CreateUser.aspx.cs:line 62
at System.Web.UI.Control.PreRenderRecursiveInternal()
at System.Web.UI.Page.ProcessRequestMain(Boolean
includeStagesBeforeAsyncPoint, Boolean includeStagesAfterAsyncPoint)

----------

INNER EXCEPTION:

The directory property cannot be found in the cache.

-----------

I have read through various web resources that SSL must be enabled for the LDAP provider/ AD LDS to allow for remote password resets invoked through code (eg.
http://geekswithblogs.net/Lance/archive/2005/08/19/LdapAuthenticationASP.aspx).  I have generated a self-signed certificate using selfssl.exe and assigned it to the Trusted Root Certificates Authorities certificate store on both the AD LDS server and the web server hosting the .NET form. I have also followed instructions on configuring SSL for AD LDS from this MSDN article:

http://technet.microsoft.com/en-us/library/cc725767.aspx

I have confirmed through ldp.exe that the SSL connection for AD LDS is working.

At a major roadblock here. Any assistance or suggestions with this much appreciated.
using(DirectoryEntry de = new DirectoryEntry(
                "LDAP://SERVERNAME:636/CN=Clients,CN=Users,CN=ADLDSSTORE,DC=SERVERNAME,DC=local",
                "CN=SERVICEACCOUNT,CN=Users,CN=ADLDSSTORE,DC=SERVERNAME,DC=local",
                "USERPASSWORD", AuthenticationTypes.SecureSocketsLayer)) {
 
                DirectoryEntry newUser = de.Children.Add("CN=testuser1", "user");
                newUser.CommitChanges();
 
                newUser.Invoke("Put", new Object[] { "displayName", "User, Test" });
                newUser.Invoke("Put", new Object[] { "givenName", "Test" });
                newUser.Invoke("Put", new Object[] { "mail", "TestUser@DOMAIN.com" });
                newUser.Invoke("Put", new Object[] { "company", "ABC" });
                newUser.Invoke("Put", new Object[] { "sn", "User" });
                newUser.Invoke("Put", new Object[] { "telephoneNumber", "1 604 123-1234" });
                newUser.Invoke("Put", new Object[] { "description", "User description." });
                newUser.CommitChanges();
 
                // EXCEPTION THROWN HERE
                newUser.Invoke("SetPassword", new Object[] { "THEUSERPASSWORD" });
 
                newUser.CommitChanges();
                newUser.Close();
}

Open in new window

0
Comment
Question by:blizzy
1 Comment
 
LVL 1

Accepted Solution

by:
blizzy earned 0 total points
ID: 24111965
Solved it....

It looks like AD LDS does not like the SetPassword command.  I found an article on how to do this in ldp.exe and adapted it for .NET:

http://technet.microsoft.com/en-us/library/cc781829.aspx

My code now reads:

                newUser.Invoke("Put", new Object[] { "userpassword", "THEPASSWORD" });
                newUser.CommitChanges();
                newUser.Close();

Open in new window

0

Featured Post

VMware Disaster Recovery and Data Protection

In this expert guide, you’ll learn about the components of a Modern Data Center. You will use cases for the value-added capabilities of Veeam®, including combining backup and replication for VMware disaster recovery and using replication for data center migration.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

Title # Comments Views Activity
Issues with windows distributed file system 2 27
AD architecture diagram 5 30
Change to file doesn't show up 16 50
Power shell 4 25
Many companies are looking to get out of the datacenter business and to services like Microsoft Azure to provide Infrastructure as a Service (IaaS) solutions for legacy client server workloads, rather than continuing to make capital investments in h…
When it comes to protecting Oracle Database servers and systems, there are a ton of myths out there. Here are the most common.
Polish reports in Access so they look terrific. Take yourself to another level. Equations, Back Color, Alternate Back Color. Write easy VBA Code. Tighten space to use less pages. Launch report from a menu, considering criteria only when it is filled…
This video shows how to use Hyena, from SystemTools Software, to bulk import 100 user accounts from an external text file. View in 1080p for best video quality.

791 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question