Searching Active Directory with .NET (Visual Studio 2005)

Download this episode

Download Video


Federal Developer Evangelist, Robert Shelton, takes you through a 12 minute walkthrough/demonstration of how to search Active Directory for users, groups, and other AD Objects.  This demonstration is using the DirectoryServices namespace of the .NET framework.  The demonstration is using Visual Studio 2005, but the code will also work as written for Visual Studio 2003.

You can find the code at my blog: 

My other AD Screencasts:

- Adding user to AD with .NET
- Adding groups and users to groups with .NET

- AD Searchfilter (Querying) Syntax:

 - List of SearchScope options:

~ Robert Shelton



Available formats for this video:

Actual format may change based on video formats available and browser capability.

    The Discussion

    • User profile image

      I'm a VIsual Basic developer. Do you have this project available in Visual Basic code?

      David Carpenter
    • User profile image
      Robert Shelton
      David, as funny as it sounds, I am a Visual Basic developer as well, but I've started doing demonstration code in C# to learn that language as well.  I don't currently have this in VB.NET, but if there is a lot of interest around a VB port, I will happily port the code and place it on the site.

      Currently I am working on some web cast for Windows Communication Foundation, otherwise, I would just do it now.  After I finish those, I will look at porting all of my screencast to both VB and C#.  This way, no one gets left out and it's easier for me, since it is more natural for me to read/write in VB.

    • User profile image

      I couldn't find the VB-Code in the net, so I just ported it myself:

      ' If you want to search in a specific path, here's the right spot.
      ' Just insert the path into "As New DirectoryEntry("LDAP://OU=Accounting,DC=World,DC=com")"
      Dim Entry As New DirectoryEntry
      Dim Searcher As New DirectorySearcher(Entry)
      Dim AdObj As SearchResult

      Searcher.SearchScope = SearchScope.Subtree

      Searcher.Filter() = "(ObjectClass=user)"

      For Each AdObj In Searcher.FindAll
      Label1.Text = Label1.Text & "CN=" & AdObj.Properties("CN").Item(0) & " | Path=" & AdObj.Path & "<br>"

      I coded it with for a webapplication.
      But the App does exactely the same as the first example.
      I hope you can use it.

    • User profile image
      First of all...great work. I had been searching for a couple of days for exactly what your screencast showed. I am having some problems though.

      Instead of the common name, I would like to display the users logon name. I have been messing around, I got a look at the target's AD schema, and have found some promising attributes to plug in. However, If I try to use and attribute that is not "mandatory" I get a "ArgumentOutOfRangeException"

      Here is my code (almost exact to yours)
      DirectoryEntry adDirecEntry = new DirectoryEntry();

                  DirectorySearcher adDirecSearch = new DirectorySearcher(adDirecEntry);

                  //set the search scope
                  adDirecSearch.SearchScope = SearchScope.Subtree;

                  //Set the filter. For this example we will be looking at all users
                  adDirecSearch.Filter = "(ObjectClass=user)";

                  //Execute the search and iterate through the result
                  //Write results to lboAD for display
                  foreach (SearchResult adObject in adDirecSearch.FindAll())

      It is at "lboAD.Items.Add(adObject.Properties["uid"][0]);" that I get the exception. At first I thought it was maybe something else, I dunno what....but it will only display results when I use a mandatory attribute, no matter the ObjectClass.

      Is it something to do with my target's AD schema? Is it something I am doing wrong?

      Thanks, and again, great work!!
    • User profile image

      Is there a way to view video in full screen?

    • User profile image

    • User profile image
      it's great code,
      but i'm using visual studio 2003 & when i run the code it gives me "The specified domain either does not exist or could not be contacted "
      so please advice

    Comments closed

    Comments have been closed since this content was published more than 30 days ago, but if you'd like to send us feedback you can Contact Us.