首页 > 解决方案 > 使用无管理员帐户获取当前登录的用户 SID

问题描述

我正在开发一个 C# 应用程序。

要使应用程序正常工作,用户必须以管理权限启动应用程序。

因此,如果没有管理员帐户的用户想要启动应用程序,他必须右键单击并选择“以其他用户身份运行”以使用管理员帐户进行身份验证。问题是,一旦使用管理员帐户登录,我就无法取回非管理员用户的 SID。

当我这样做时:

WindowsIdentity.GetCurrent().User

它返回用户登录的管理员用户的 SID。但是,我想恢复使用管理员帐户登录的用户的 SID。

标签: c#wpfwindowssecuritysid

解决方案


我找到了解决方案:)

我使用Cassia来查找用户名:

ITerminalServicesManager manager = new TerminalServicesManager();
ITerminalServicesSession session = manager.CurrentSession;

选择session.UserName与and匹配的所有用户session.DomainName

ManagementObjectSearcher mos = new ManagementObjectSearcher("select * from Win32_Account where Name='" + session.UserName + "' AND Domain='" + session.DomainName + "'");
ManagementObjectCollection Users = mos.Get();

找到带有用户 SID 的 %appData%之后:

// Get first user
ManagementObject[] arr = new ManagementObject[1];
Users.CopyTo(arr, 0);
ManagementObject User = arr[0];

// Found the %appData%
const string regValueLocalAppData = @"AppData";
const string regKeyShellFolders = @"HKEY_USERS\$SID$\Software\Microsoft\Windows\" +
                                                  @"CurrentVersion\Explorer\Shell Folders";

var localAppDataPath = Microsoft.Win32.Registry.GetValue(regKeyShellFolders.Replace("$SID$", User["SID"].ToString()), regValueLocalAppData, null) as string;

// Check if %appData% is not empty// Le dossier %appData% existe
if (!string.IsNullOrWhiteSpace(localAppDataPath))
{
    PathToRoaming = localAppDataPath;
}

也可以创建路径并检查它是否存在:

public string GetAppdataPath() {
    string PathToRoaming = "";

    ITerminalServicesManager manager = new TerminalServicesManager();
    ITerminalServicesSession session = manager.CurrentSession;

    // Get path to Users directory
    Guid UserProfilesGuid = new Guid("0762D272-C50A-4BB0-A382-697DCD729B80");
    IntPtr pPath;
    SHGetKnownFolderPath(UserProfilesGuid, 0, IntPtr.Zero, out pPath);
    string PathToUsers = System.Runtime.InteropServices.Marshal.PtrToStringUni(pPath);
    System.Runtime.InteropServices.Marshal.FreeCoTaskMem(pPath);

    // Build path
    string PathToRoamingDir = String.Format("{0}\\{1}\\AppData\\Roaming", PathToUsers, session.UserName);

   if (Directory.Exists(PathToRoamingDir))
   {
      PathToRoaming = PathToRoamingDir;
   }
}

[System.Runtime.InteropServices.DllImport("shell32.dll")]
static extern int SHGetKnownFolderPath([System.Runtime.InteropServices.MarshalAs(System.Runtime.InteropServices.UnmanagedType.LPStruct)] Guid rfid, uint dwFlags, IntPtr hToken, out IntPtr pszPath);

推荐阅读