.NET控制台应用程序中的Thread.CurrentPrincipal

Use*_*rol 14 .net security .net-4.0 principal windows-7

这是一个简单的控制台应用程序,我在命令提示符下运行:

using System;
using System.Threading;
namespace Test
{
    internal class Runner
    {
        [STAThread]
        static void Main(string[] args)
        {
            Console.WriteLine(Thread.CurrentPrincipal.GetType().Name);
            Console.WriteLine(Thread.CurrentPrincipal.Identity.Name);
        }
    }
}
Run Code Online (Sandbox Code Playgroud)

输出为"GenericPrincipal",空字符串为身份名称.为什么运行时构造GenericPrincipal而不是WindowsPrincipal?我如何强制它WindowsPrincipal从启动过程的安全令牌构建(在我的情况下为cmd.exe)?

wel*_*tty 32

您必须告诉您的应用使用PrincipalPolicy.你会添加

AppDomain.CurrentDomain.SetPrincipalPolicy(PrincipalPolicy.WindowsPrincipal);
Run Code Online (Sandbox Code Playgroud)

使你的代码看起来像:

using System;
using System.Threading;
using System.Security.Principal;

namespace Test
{
    internal class Runner
    {
        [STAThread]
        static void Main(string[] args)
        {
            AppDomain.CurrentDomain.SetPrincipalPolicy(PrincipalPolicy.WindowsPrincipal);
            Console.WriteLine(Thread.CurrentPrincipal.GetType().Name);
            Console.WriteLine(Thread.CurrentPrincipal.Identity.Name);
        }
    }
}
Run Code Online (Sandbox Code Playgroud)

http://msdn.microsoft.com/en-us/library/system.appdomain.setprincipalpolicy.aspx