NameIdentifier vs ObjectIdentifier

前端 未结 2 1727
梦谈多话
梦谈多话 2021-01-07 18:03

I have a multitenant ASP.NET application using OpenIdConnect and Azure AD as an Identity provider for Office 365. When the user is authenticated I receive my claims in

相关标签:
2条回答
  • 2021-01-07 18:30

    Precisely, if I create another application in Azure AD then, the NameIdentifier will not be the same for the same real Office365 user.

    I made a quick test as following:

    Register a multi-tenant-webapp and single-tenant-webapp in AD Contoso.

    Log in with user1@contoso.onmicrosoft.com and get the name identifier in both web applications, it turns out the name identifier are the same in both applications. So the name identifier should be able to identify users cross applications, but it can not be used to identify the user in Azure AD.

    For the object identifier, it is a GUID which you can used to identify a user in Azure AD. For example, you can use object identifier to query the user in Azure AD.

    Powershell:

    $msolcred = get-credential
    connect-msolservice -credential $msolcred
    get-msoluser -ObjectId "{guid:object_identifier}"  
    

    And more importantly, can you confirm that the ObjectIdentifier can be used as an "universal" identifier for a user in any Office 365 subscription.

    Based on my understanding, the object identifier is a GUID which can identify for a user in Office 365 subscriptions.

    0 讨论(0)
  • 2021-01-07 18:40

    Or to put it another way:

    The NameIdentifier is the GUID of the Application which is registered in Azure AD. This won't change whether it's a single or multi-tenant application. It won't matter if you are using client credentials (i.e. AppId and AppSecret) to authenticate AS the application or using logging using real user credentials (i.e. delegated), the NameIdentifier will remain the same.

    The ObjectIdentifier is the User Principal Name (UPN) for the user when using delegation or Service Principal Name (SPN) of the application when using client creds.

    The reason you see different ObjectIdentifier values when an application is multi-tenant is that there is a separate and unique SPN in EACH TENANT which points back to the ApplicationGUID in the tenant where the application is registered. This SPN is used to assign rights to the application against resources in each tenant.

    0 讨论(0)
提交回复
热议问题