Accessing Active Directory in ASP.NET?

后端 未结 5 514
[愿得一人]
[愿得一人] 2021-02-04 18:36

I use a console application to write some test code:

    /// 
    /// Returns AD information for a specified userID.
    /// 
    /         


        
相关标签:
5条回答
  • 2021-02-04 18:57

    The easiest way around this is to make your web application pool run as a domain account that has the required access. This avoids you having to manage the secure storing of a password. Don't forget to make the account a member of the IIS_WPG local group. If you do decide to use impersonation you will have to configure Kerberos delegation as well as changing the ASP.NET configuration to impersonate. This will involve making the application pool run as a domain account, granting that domain account permission to delegate credentials (the delegation tab of the account properties in the AD users and computers MMC). Then ensuring that the website is set to use negoiate in the metabase (this is the default on IIS6, not sure about other versions) and registering an SPN for the new domain account.

    Edit: Your 'Unknown authentication' error sounds like mis-configured delegation. Check that the account your app pool is running as is trusted for delegation, that IIS is set to use ONLY windows authentication and that a valid SPN is registered for the app pool identity account.

    0 讨论(0)
  • 2021-02-04 18:58

    You could also try including the domain in the login

    adSharepointUsers = new DirectoryEntry("LDAP://MyDomain","MyDomain/ADUser","password");
    
    0 讨论(0)
  • 2021-02-04 19:07

    If its an intranet application that uses windows authentication, then you can wrap your AD call in a impersonation-context of the user.

    Something like:

    using (((System.Security.Principal.WindowsIdentity)User.Identity).Impersonate())
    {
        // Do your AD stuff here
    }
    
    0 讨论(0)
  • 2021-02-04 19:08

    Alternatively you could specify identity impersonate=true in the web.config and the request to Active directory will be sent as the calling user instead of Machine\ASPNET

    Edit: If you are getting the authentication error see PIPTHEGEEK's post you will have to trust your web server for delegation, however be careful with trusting for delegation (since it opens another can of worms for security types). You have to allow the web server to pass the credentials of the current user to AD.

    If possible, go to AD properties for the computer, select the delegation tab, and select "Trust this computer for delegation to any service (Kerberos Only)

    See if that works. If it does, you can further fine grain the permissions by using the third option which states

    "Trust this computer for delegation to specified services only"

    Then select "Use Kerberos Only"

    and in the "services to which this account can present delegated credentials", add the relevant service information.

    0 讨论(0)
  • 2021-02-04 19:12

    Yes. You need to give it a directory connection string. A console app (running as you) runs with your credentials, including directory access. An ASP.NET app runs with the ASPNET user's credentials, which are local to the system the app is running on, not directory-global.

    0 讨论(0)
提交回复
热议问题