Обнаружение пользователя, вошедшего в систему с помощью приложения ASP.NET - PullRequest
2 голосов
/ 27 марта 2009

Я хочу разработать приложение ASP.NET, которое может обнаружить пользователя, вошедшего в домен Windows. Эти учетные данные будут использоваться для входа в приложение ASP.NET.

Как я могу это сделать?

Спасибо!

Ответы [ 5 ]

7 голосов
/ 27 марта 2009

В IIS включите встроенную проверку подлинности Windows и в коде, если вы используете:

Request.ServerVariables["LOGON_USER"]

вернет имя пользователя Windows вошедшего в систему пользователя, то есть MYDOMAIN \ MYUSERNAME

1 голос
/ 27 марта 2009

Для ASP.net вы, вероятно, можете использовать

HttpContext.Current.User.Identity

Если IIS настроен правильно (по крайней мере, без анонимных входов)

1 голос
/ 27 марта 2009

Вот код C #, который я использую для аутентификации в Active Directory

using System;
using System.DirectoryServices;

namespace XYZcompany.Enterprise
{
  public class AuthenicationMgr
  {
    private static readonly int AD_ERR_LOGON_FAIL = -2147023570;
    private static readonly string _path = "LDAP://xxx.yyy.ggg";
    private static readonly string _domain = "xxx.yyy.ggg";

    public static bool IsAuthenticated(string username, string pwd)
    {
      bool authenticatedFlag = true;
      string domainAndUsername = _domain + "\\" + username;
      DirectoryEntry entry = new DirectoryEntry(_path, domainAndUsername, pwd);
      try
      {
        // Bind to the native AdsObject to force authentication.
        Object obj = entry.NativeObject;
        DirectorySearcher search = new DirectorySearcher(entry);

        search.Filter = "(SAMAccountName=" + username + ")";
        search.PropertiesToLoad.Add("cn");
        SearchResult result = search.FindOne();

        if (result == null)
        {
          authenticatedFlag = false;
        }
        else
        {
          authenticatedFlag = true;
        }
      }
      catch (System.Runtime.InteropServices.COMException ex)
      {
        if (ex.ErrorCode == AD_ERR_LOGON_FAIL)
        {
          authenticatedFlag = false;
        }
        else
        {
          throw new ApplicationException("Unable to authenticate user due to system error.", ex);
        }
      }
      return authenticatedFlag;
    }
  }
}
0 голосов
/ 27 марта 2009

Вам следует обратиться к поставщику активного каталога. Он встроен в ASP.NET.

0 голосов
/ 27 марта 2009
System.Security.Principal.WindowsIdentity.GetCurrent().User.ToString
...