オプション「匿名ユーザーを許可する」を使用して、現在ASP WebページにログオンしているユーザーのWindowsログインを取得する公式の方法またはハックが可能かどうか疑問に思いますか? または、おそらくインポートされたWindows DLLを使用していますか?
通常、「匿名ユーザーの拒否」を使用すると、ログインウィンドウを簡単に取得できることがわかります。しかし、特別な理由で、Windows ログインを取得して匿名ユーザーを受け入れたいと考えています。そのため、Windows ログインがデータベース内のユーザーである場合、別の Web ページにリダイレクトします。
私はそれを確認しました:(ただし、windowsLogin ==常に空です)
ASP - C#
string windowsLogin = System.Security.Principal.WindowsPrincipal.Current.Identity.Name;
string windowsLogin = System.Threading.Thread.CurrentPrincipal.Identity.Name;
string windowsLogin = System.Net.CredentialCache.DefaultCredentials.ToString();
string windowsLogin = Request.ServerVariables["LOGON_USER"].ToString();
Web.config
<authorization>
<deny users ="?" /><!-- Deny acces to anonymous users-->
<allow users ="*" /><!-- Allow acces to every users-->
</authorization>
<identity impersonate="true"/>
<authentication mode="Forms">
<forms loginUrl="./WebLogin.aspx" defaultUrl="./default.aspx" timeout="12" path="/" name=".ASPXFORMSAUTH" slidingExpiration="true" />
</authentication>