无法在UWP应用程序中获取某些用户帐户信息 – 内部部署活动目录(非Azure AD)

在UWP应用程序中,我启用了User Account Informationfunction。

我需要获取当前登录用户的用户名和域名(每个用户名单独)(用户使用内部部署的Active Directory帐户登录 – 非Azure AD )。

例如,用户将使用用户名user1登录到Active Directory域domain1 。 即domain1\user1

我使用以下代码来尝试获取所需的详细信息:

 IReadOnlyList users = await User.FindAllAsync(); var user = users.FirstOrDefault(); // get domain var data1 = await user.GetPropertyAsync(KnownUserProperties.DomainName); string strDomainName = (string)data1; // get username var data2 = await user.GetPropertyAsync(KnownUserProperties.AccountName); string strUserName = (string)data2; 

问题:

  • strDomainName返回domain1.com\user1 。 为什么这包括我们所有域名的.com部分? 在c#winforms应用程序中,我们可以轻松获取domain1\user1而没有任何问题。
  • strUserName返回一个空字符串。 即“”。 为什么这不会返回任何价值?

我还检查了以下内容:

  • KnownUserProperties.FirstName返回一个空字符串。 即“”
  • KnownUserProperties.LastName返回一个空字符串。 即“”
  • KnownUserProperties.PrincipalName返回一个空字符串。 即“”
  • KnownUserProperties.ProviderName返回一个空字符串。 即“”
  • KnownUserProperties.GuestHost返回一个空字符串。 即“”

我需要启用类似于User Account Informationfunction的其他任何内容吗? 或者是否有任何其他权限需要授予应用程序才能获取此信息?

我知道我可以获取strDomainName的值并执行字符串函数来获得我需要的东西。 但我想知道是否有任何方法可以直接获取此信息。 同样好奇为什么KnownUserProperties.AccountName和上面列出的其他属性如FirstNameLastName等只返回一个空字符串。

我正在运行以下版本的Windows:

Windows版本

我有以下设置作为Target versionMin Version

目标版本和最低版本

为了validation,我还使用Microsoft的GitHub对UserInfo示例项目进行了测试,得到了以下输出:

UserInfo示例项目输出

Settings > Privacy > Account Info自动启用以下内容。

TestApp是我尝试过的应用程序, User Info C# Sample是GitHub的示例应用程序:

AccountInfo”>

更新:

在启用Enterprise Authenticationfunction后, KnownUserProperties.PrincipalName会返回预期值。 user1@domain1.com 但是,上面列出的其他属性,如FirstNameLastName等只返回一个空字符串,我仍然无法找到任何返回domain1\user1属性(没有.com部分)

您尝试访问的信息不可靠,因为它们(如您所述)不必设置,并且通常也可以通过隐私设置限制访问。

我遇到了类似的问题,建议您使用UWP OneDrive API

 using Microsoft.OneDrive.Sdk; 

然后请求wl.basic范围。 此范围至少包含可靠的用户名。

 public static async Task GetAuthenticatedClient() { string oneDriveConsumerBaseUrl = "https://api.onedrive.com/v1.0"; var scopes = new List { "wl.signin", "wl.basic", }; Task authTask; var onlineIdAuthProvider = new OnlineIdAuthenticationProvider(scopes.ToArray()); authTask = onlineIdAuthProvider.RestoreMostRecentFromCacheOrAuthenticateUserAsync(); oneDriveClient = new OneDriveClient(oneDriveConsumerBaseUrl, onlineIdAuthProvider); AuthProvider = onlineIdAuthProvider; try { await authTask; if (!AuthProvider.IsAuthenticated) { return false; } } catch (ServiceException exception) { // Swallow the auth exception but write message for debugging. //Debug.WriteLine(exception.Error.Message); return false; } return true; } 

至于域名,我不确定,但您可以尝试通过Environment.UserDomainName访问它,如MSDN或Windows.Networking.Connectivity.NetworkInformation.GetHostNames()所述,如此处所述。