你当前正在访问 Microsoft Azure Global Edition 技术文档网站。 如果需要访问由世纪互联运营的 Microsoft Azure 中国技术文档网站,请访问 https://docs.azure.cn

使用 Azure Active Directory B2C 设置通过 LinkedIn 帐户注册与登录

重要

自 2025 年 5 月 1 日起,Azure AD B2C 将不再可供新客户购买。 在我们的常见问题解答中了解详细信息

在开始之前,请使用此页面顶部的 “选择策略类型 选择器”来选择要设置的策略类型。 Azure Active Directory B2C 提供了两种定义用户如何与应用程序交互的方法:通过预定义的用户流,或者通过可完全配置的自定义策略。 对于每种方法,本文中所需的步骤都不同。

注释

在 Azure Active Directory B2C 中,自定义策略 主要用于解决复杂场景。 对于大多数场景,我们建议您使用内置的用户流。 如果未这样做,请通过 Active Directory B2C 中的自定义策略入门来了解自定义策略初学者包。

先决条件

创建LinkedIn应用程序

若要在 Azure Active Directory B2C(Azure AD B2C)中使用LinkedIn帐户为用户启用登录,需要在 LinkedIn开发人员网站中创建应用程序。 如果还没有LinkedIn帐户,可以注册。https://www.linkedin.com/

  1. 使用LinkedIn帐户凭据登录到LinkedIn 开发人员网站
  2. 选择 “我的应用”,然后单击“ 创建应用”。
  3. 输入 应用名称LinkedIn页面隐私策略 URL应用徽标
  4. 同意LinkedIn API 使用条款 ,然后单击“ 创建应用”。
  5. 选择 “身份验证 ”选项卡。在 “身份验证密钥”下,复制 客户端 ID客户端机密的值。 将 LinkedIn 配置为租户中的标识提供者时需要这两个值。 客户端密码 是重要的安全凭据。
  6. 选择 应用的授权重定向 URL 旁边的编辑图标,然后选择 添加重定向 URL。 输入 https://your-tenant-name.b2clogin.com/your-tenant-name.onmicrosoft.com/oauth2/authresp。 如果使用 自定义域,请输入 https://your-___domain-name/your-tenant-name.onmicrosoft.com/oauth2/authresp。 将 your-tenant-name 替换为租户的名称,将 your-___domain-name 替换为您的自定义域。 输入租户名称时,必须全部使用小写字母,即使租户是使用大写字母在 Azure AD B2C 中定义的,也是如此。 选择更新
  7. 默认情况下,您的LinkedIn应用未获得与登录相关范围的批准。 若要请求评审,请选择产品选项卡,然后选择使用OpenID Connect的LinkedIn登录。 审核完成后,所需的权限范围将添加到您的应用程序中。

    注释

    可以在 OAuth 2.0 范围部分中的“身份验证”选项卡上查看应用当前允许的范围。

将LinkedIn配置为标识提供者

  1. 使用至少具有外部标识提供者管理员权限的帐户登录到 Azure 门户
  2. 如果有权访问多个租户,请选择顶部菜单中的“设置”图标,从“目录 + 订阅”菜单切换到你的 Azure AD B2C 租户。
  3. 在“门户设置 | 目录+订阅”页上的“目录名称”列表中找到你的 Azure AD B2C 目录,然后选择“切换”。
  4. 选择 Azure 门户左上角的“所有服务” ,搜索并选择 Azure AD B2C
  5. 选择 “标识提供者”,然后选择“ 新建 OpenID Connect 提供程序”。
  6. 输入“名称”。 例如, LinkedIn-OIDC
  7. 对于 元数据 URL,请输入 https://www.linkedin.com/oauth/.well-known/openid-configuration
  8. 对于 客户端 ID,输入前面创建的LinkedIn应用程序的客户端 ID。
  9. 对于“客户端密码”,输入已记录的客户端密码。
  10. 对于 Scope,请输入 openid profile email
  11. 对于 响应类型,请输入 代码
  12. 对于 用户 ID,请输入 电子邮件
  13. 对于 显示名称,请输入 名称
  14. 对于 给定的名称,请输入 given_name
  15. 对于 姓氏,请输入 family_name
  16. 对于 “电子邮件”,请输入 电子邮件
  17. 选择“保存”

将LinkedIn标识提供者添加到用户流

此时,LinkedIn 标识提供者已设置,但还不能在任何登录页中使用。 若要将LinkedIn标识提供者添加到用户流,

  1. 在 Azure AD B2C 租户中,选择“用户流” 。
  2. 单击要添加 LinkedIn 标识提供者的用户流。
  3. “自定义标识提供者”下,选择 “LinkedIn-OIDC”。
  4. 选择“保存”
  5. 若要测试策略,请选择“运行用户流”。
  6. 对于“应用程序”,请选择前面已注册的名为“testapp1”的 Web 应用程序。 “回复 URL”应显示为 https://jwt.ms
  7. 选择“运行用户流”按钮。
  8. 在注册或登录页中,选择 LinkedIn-OIDC 以使用 LinkedIn 帐户登录。

如果登录过程成功,浏览器将重定向到 https://jwt.ms,后者显示 Azure AD B2C 返回的令牌内容。

创建策略密钥

需要存储以前在 Azure AD B2C 租户中记录的客户端密码。

  1. 登录到 Azure 门户
  2. 如果有权访问多个租户,请选择顶部菜单中的“设置”图标,从“目录 + 订阅”菜单切换到你的 Azure AD B2C 租户。
  3. 在“门户设置 | 目录+订阅”页上的“目录名称”列表中找到你的 Azure AD B2C 目录,然后选择“切换”。
  4. 选择 Azure 门户左上角的“所有服务”,然后搜索并选择“Azure AD B2C” 。
  5. 在“概述”页上选择“标识体验框架”。
  6. 选择“策略密钥”,然后选择“添加”。
  7. 对于“选项”,选择 Manual
  8. 输入策略密钥的名称。 例如,LinkedInSecret。 前缀“B2C_1A_”会自动添加到密钥名称中。
  9. “机密”中,输入之前记录的客户端密码。
  10. 在“密钥用法”处选择
  11. 单击 “创建”

将LinkedIn配置为标识提供者

若要允许用户使用 LinkedIn 帐户登录,需将该帐户定义为 Azure AD B2C 可通过终结点与其进行通信的声明提供程序。 该终结点将提供一组声明,Azure AD B2C 使用这些声明来验证特定的用户是否已完成身份验证。

通过在策略扩展文件中的 ClaimsProviders 元素中添加 LinkedIn 帐户,将其定义为声明提供者。

  1. 在编辑器中打开 SocialAndLocalAccounts/TrustFrameworkExtensions.xml 文件。 此文件位于作为先决条件之一下载的 自定义策略初学者包 中。

  2. 找到 ClaimsProviders 元素。 如果该元素不存在,请在根元素下添加它。

  3. 添加一个新的 ClaimsProvider,如下所示:

    <ClaimsProvider>
      <Domain>linkedin.com</Domain>
      <DisplayName>LinkedIn-OIDC</DisplayName>
      <TechnicalProfiles>
          <TechnicalProfile Id="LinkedIn-OIDC">
          <DisplayName>LinkedIn</DisplayName>
          <Protocol Name="OpenIdConnect" />
          <Metadata>
              <Item Key="METADATA">https://www.linkedin.com/oauth/.well-known/openid-configuration</Item>
              <Item Key="scope">openid profile email</Item>
              <Item Key="HttpBinding">POST</Item>
              <Item Key="response_types">code</Item>
              <Item Key="UsePolicyInRedirectUri">false</Item>
              <Item Key="client_id">Your LinkedIn application client ID</Item>
          </Metadata>
          <CryptographicKeys>
              <Key Id="client_secret" StorageReferenceId="B2C_1A_LinkedInSecret" />
          </CryptographicKeys>
          <InputClaims />
          <OutputClaims>
              <OutputClaim ClaimTypeReferenceId="issuerUserId" PartnerClaimType="email" />
              <OutputClaim ClaimTypeReferenceId="givenName" PartnerClaimType="given_name" />
              <OutputClaim ClaimTypeReferenceId="surname" PartnerClaimType="family_name" />
              <OutputClaim ClaimTypeReferenceId="identityProvider" DefaultValue="linkedin.com" AlwaysUseDefaultValue="true" />
              <OutputClaim ClaimTypeReferenceId="authenticationSource" DefaultValue="socialIdpAuthentication" AlwaysUseDefaultValue="true" />
          </OutputClaims>
          <OutputClaimsTransformations>
              <OutputClaimsTransformation ReferenceId="CreateRandomUPNUserName" />
              <OutputClaimsTransformation ReferenceId="CreateUserPrincipalName" />
              <OutputClaimsTransformation ReferenceId="CreateAlternativeSecurityId" />
              <OutputClaimsTransformation ReferenceId="CreateSubjectClaimFromAlternativeSecurityId" />
          </OutputClaimsTransformations>
          <UseTechnicalProfileForSessionManagement ReferenceId="SM-SocialLogin" />
          </TechnicalProfile>
      </TechnicalProfiles>
    </ClaimsProvider>
    
  4. client_id 的值替换为之前记录的 LinkedIn 应用程序的客户端 ID。

  5. 保存文件。

添加用户旅程

此时,标识提供者已设置,但还不能在任何登录页中使用。 如果你没有自己的自定义用户旅程,请创建现有模板用户旅程的副本,否则,请继续执行下一步。

  1. 打开初学者包中的 TrustFrameworkBase.xml 文件。
  2. 找到并复制包含 Id="SignUpOrSignIn" 元素的完整内容。
  3. 打开 TrustFrameworkExtensions.xml 并找到 UserJourneys 元素。 如果该元素不存在,请添加一个。
  4. 将您复制的 UserJourney 元素的完整内容粘贴到 UserJourneys 元素下作为其子项。
  5. 对用户旅程的 ID 进行重命名。 例如,Id="CustomSignUpSignIn"

将标识提供者添加到用户旅程

现在你已拥有用户旅程,请将新的身份提供者添加到用户旅程中。 首先添加一个“登录”按钮,然后将该按钮链接到某个操作。 该操作是前面创建的技术配置文件。

  1. 在用户旅程中,查找包含 Type="CombinedSignInAndSignUp"Type="ClaimsProviderSelection" 的业务流程步骤元素。 通常这是第一个编排步骤。 ClaimsProviderSelections 元素包含用户可以用来登录的标识提供者列表。 元素的顺序将决定向用户显示的登录按钮的顺序。 添加ClaimsProviderSelection XML 元素。 将 TargetClaimsExchangeId 的值设置为易记名称。

  2. 在下一个编排步骤中,添加 ClaimsExchange 元素。 将 ID 设为目标声明交换 ID 的值。将 TechnicalProfileReferenceId 的值更新为先前创建的技术配置文件的 ID。

下面的 XML 演示了使用标识提供者进行用户旅程的前两个业务流程步骤:

<OrchestrationStep Order="1" Type="CombinedSignInAndSignUp" ContentDefinitionReferenceId="api.signuporsignin">
  <ClaimsProviderSelections>
    ...
    <ClaimsProviderSelection TargetClaimsExchangeId="LinkedInExchange" />
  </ClaimsProviderSelections>
  ...
</OrchestrationStep>

<OrchestrationStep Order="2" Type="ClaimsExchange">
  ...
  <ClaimsExchanges>
    <ClaimsExchange Id="LinkedInExchange" TechnicalProfileReferenceId="LinkedIn-OIDC" />
  </ClaimsExchanges>
</OrchestrationStep>

配置信赖方策略

信赖方策略(例如 SignUpSignIn.xml)指定 Azure AD B2C 将执行的用户旅程。 在信赖方内查找 DefaultUserJourney 元素。 更新 ReferenceId,使其与已在其中添加标识提供者的用户旅程 ID 匹配

在以下示例中,对于 CustomSignUpSignIn 用户旅程,将 ReferenceId 设置为 CustomSignUpSignIn

<RelyingParty>
  <DefaultUserJourney ReferenceId="CustomSignUpSignIn" />
  ...
</RelyingParty>

上传自定义策略

  1. 登录到 Azure 门户
  2. 在门户工具栏中选择“目录 + 订阅”图标,然后选择包含 Azure AD B2C 租户的目录。
  3. 在 Azure 门户中,搜索并选择 Azure AD B2C
  4. 在“策略”下,选择“Identity Experience Framework”
  5. 选择“上传自定义策略”,然后上传已更改的两个策略文件,其顺序为:先上传扩展策略(例如 ),然后上传信赖方策略(例如 TrustFrameworkExtensions.xml)。

测试自定义策略

  1. 选择依赖方策略,例如 B2C_1A_signup_signin
  2. 对于应用程序,请选择您前面注册的 Web 应用程序。 “回复 URL”应显示为 https://jwt.ms
  3. 选择“立即运行”按钮。
  4. 在注册或登录页中,选择 LinkedIn-OIDC 以使用 LinkedIn 帐户登录。

如果登录过程成功,浏览器将重定向到 https://jwt.ms,后者显示 Azure AD B2C 返回的令牌内容。

从 v1.0 迁移到 v2.0

LinkedIn最近 将其 API 从 v1.0 更新到 v2.0。 若要将现有配置迁移到新配置,请使用以下部分中的信息更新技术配置文件中的元素。

替换 Metadata 中的项

在 TechnicalProfile 的现有 Metadata 元素中,更新以下项中的下列 Item 元素

<Item Key="ClaimsEndpoint">https://api.linkedin.com/v1/people/~:(id,first-name,last-name,email-address,headline)</Item>
<Item Key="scope">r_emailaddress r_basicprofile</Item>

更改为:

<Item Key="ClaimsEndpoint">https://api.linkedin.com/v2/me</Item>
<Item Key="scope">r_emailaddress r_liteprofile</Item>

向 Metadata 添加项

TechnicalProfile元数据中,添加以下 Item 元素:

<Item Key="external_user_identity_claim_id">id</Item>
<Item Key="BearerTokenTransmissionMethod">AuthorizationHeader</Item>
<Item Key="ResolveJsonPathsInJsonTokens">true</Item>

更新 OutputClaims

在 TechnicalProfile 的现有 OutputClaims 中,更新以下项中的下列 OutputClaim 元素:

<OutputClaim ClaimTypeReferenceId="givenName" PartnerClaimType="firstName" />
<OutputClaim ClaimTypeReferenceId="surname" PartnerClaimType="lastName" />

更改为:

<OutputClaim ClaimTypeReferenceId="givenName" PartnerClaimType="firstName.localized" />
<OutputClaim ClaimTypeReferenceId="surname" PartnerClaimType="lastName.localized" />

添加新的 OutputClaimsTransformation 元素

TechnicalProfileOutputClaimsTransformations 中,添加以下 OutputClaimsTransformation 元素:

<OutputClaimsTransformation ReferenceId="ExtractGivenNameFromLinkedInResponse" />
<OutputClaimsTransformation ReferenceId="ExtractSurNameFromLinkedInResponse" />

定义新的声明转换和声明类型

在上一个步骤中,你添加了需要定义的新声明转换。 若要定义声明转换,请将它们添加到 ClaimsTransformations 列表。 如果没有在文件中定义的 ClaimsTransformations 元素,请添加父 XML 元素,如下所示。 声明转换还需要一个名为 nullStringClaim 的新声明类型。

应将 BuildingBlocks 元素添加到文件顶部附近。 请参阅 TrustframeworkBase.xml 作为示例。

<BuildingBlocks>
  <ClaimsSchema>
    <!-- Claim type needed for LinkedIn claims transformations -->
    <ClaimType Id="nullStringClaim">
      <DisplayName>nullClaim</DisplayName>
      <DataType>string</DataType>
      <AdminHelpText>A policy claim to store unuseful output values from ClaimsTransformations. This claim should not be used in a TechnicalProfiles.</AdminHelpText>
      <UserHelpText>A policy claim to store unuseful output values from ClaimsTransformations. This claim should not be used in a TechnicalProfiles.</UserHelpText>
    </ClaimType>
  </ClaimsSchema>

  <ClaimsTransformations>
    <!-- Claim transformations needed for LinkedIn technical profile -->
    <ClaimsTransformation Id="ExtractGivenNameFromLinkedInResponse" TransformationMethod="GetSingleItemFromJson">
      <InputClaims>
        <InputClaim ClaimTypeReferenceId="givenName" TransformationClaimType="inputJson" />
      </InputClaims>
      <OutputClaims>
        <OutputClaim ClaimTypeReferenceId="nullStringClaim" TransformationClaimType="key" />
        <OutputClaim ClaimTypeReferenceId="givenName" TransformationClaimType="value" />
      </OutputClaims>
    </ClaimsTransformation>
    <ClaimsTransformation Id="ExtractSurNameFromLinkedInResponse" TransformationMethod="GetSingleItemFromJson">
      <InputClaims>
        <InputClaim ClaimTypeReferenceId="surname" TransformationClaimType="inputJson" />
      </InputClaims>
      <OutputClaims>
        <OutputClaim ClaimTypeReferenceId="nullStringClaim" TransformationClaimType="key" />
        <OutputClaim ClaimTypeReferenceId="surname" TransformationClaimType="value" />
      </OutputClaims>
    </ClaimsTransformation>
  </ClaimsTransformations>
</BuildingBlocks>

获取电子邮件地址

在从 v1.0 迁移到 v2.0 LinkedIn过程中,需要对另一个 API 进行额外的调用才能获取电子邮件地址。 如果需要在注册期间获取电子邮件地址,请执行以下作:

  1. 完成上述步骤,使 Azure AD B2C 能够与LinkedIn联合,让用户登录。 作为联合身份验证的一部分,Azure AD B2C 接收LinkedIn的访问令牌。

  2. 将 LinkedIn 访问令牌保存到声明中。 请参阅此处的说明

  3. 添加以下声明提供程序以向 LinkedIn 的 /emailAddress API 发出请求。 若要授权此请求,需要LinkedIn访问令牌。

    <ClaimsProvider>
      <DisplayName>REST APIs</DisplayName>
      <TechnicalProfiles>
        <TechnicalProfile Id="API-LinkedInEmail">
          <DisplayName>Get LinkedIn email</DisplayName>
          <Protocol Name="Proprietary" Handler="Web.TPEngine.Providers.RestfulProvider, Web.TPEngine, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null" />
          <Metadata>
              <Item Key="ServiceUrl">https://api.linkedin.com/v2/emailAddress?q=members&amp;projection=(elements*(handle~))</Item>
              <Item Key="AuthenticationType">Bearer</Item>
              <Item Key="UseClaimAsBearerToken">identityProviderAccessToken</Item>
              <Item Key="SendClaimsIn">Url</Item>
              <Item Key="ResolveJsonPathsInJsonTokens">true</Item>
          </Metadata>
          <InputClaims>
              <InputClaim ClaimTypeReferenceId="identityProviderAccessToken" />
          </InputClaims>
          <OutputClaims>
              <OutputClaim ClaimTypeReferenceId="email" PartnerClaimType="elements[0].handle~.emailAddress" />
          </OutputClaims>
          <UseTechnicalProfileForSessionManagement ReferenceId="SM-Noop" />
        </TechnicalProfile>
      </TechnicalProfiles>
    </ClaimsProvider>
    
  4. 将以下业务流程步骤添加到用户旅程中,以便在用户使用 LinkedIn 登录时触发 API 声明提供程序。 请确保正确更新 Order 号码。 紧接着可触发 LinkedIn 技术配置文件的业务流程步骤添加此步骤。

    <!-- Extra step for LinkedIn to get the email -->
    <OrchestrationStep Order="3" Type="ClaimsExchange">
      <Preconditions>
        <Precondition Type="ClaimsExist" ExecuteActionsIf="false">
          <Value>identityProvider</Value>
          <Action>SkipThisOrchestrationStep</Action>
        </Precondition>
        <Precondition Type="ClaimEquals" ExecuteActionsIf="false">
          <Value>identityProvider</Value>
          <Value>linkedin.com</Value>
          <Action>SkipThisOrchestrationStep</Action>
        </Precondition>
      </Preconditions>
      <ClaimsExchanges>
        <ClaimsExchange Id="GetEmail" TechnicalProfileReferenceId="API-LinkedInEmail" />
      </ClaimsExchanges>
    </OrchestrationStep>
    

在注册期间从LinkedIn获取电子邮件地址是可选的。 如果选择不从LinkedIn获取电子邮件,但在注册期间需要一封电子邮件,则需要用户手动输入电子邮件地址并对其进行验证。

有关使用LinkedIn标识提供者的策略的完整示例,请参阅 自定义策略初学者包

从 v1.0 迁移到 v2.0

LinkedIn最近 将其 API 从 v1.0 更新到 v2.0。 在迁移过程中,Azure AD B2C 只能在注册期间获取LinkedIn用户的全名。 如果电子邮件地址是注册过程中收集的属性之一,用户必须手动输入电子邮件地址并对其进行验证。