RelyingParty

注意

在 Azure Active Directory B2C 中,自定义策略主要用于解决复杂的情况。 在大多数情况下,建议你使用内置用户流。 如果尚未这样做,请从 Active Directory B2C 中的自定义策略入门了解自定义策略新手包。

RelyingParty 元素指定用户旅程,以执行当前对 Azure Active Directory B2C (Azure AD B2C) 的请求。 它还指定依赖方 (RP) 应用程序需要作为已颁发令牌一部分的声明列表。 RP 应用程序(例如 Web、移动或桌面应用程序)调用 RP 策略文件。 RP 策略文件执行特定任务,例如登录、重置密码,或编辑配置文件。 多个应用程序可以使用相同的 RP 策略,单个应用程序可以使用多个策略。 所有 RP 应用程序都接收具有相同声明的令牌,用户会经历相同的用户旅程。

下面的示例演示 B2C_1A_signup_signin 策略文件中的 RelyingParty 元素:

<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<TrustFrameworkPolicy
  xmlns:xsi="https://www.w3.org/2001/XMLSchema-instance"
  xmlns:xsd="https://www.w3.org/2001/XMLSchema"
  xmlns="http://schemas.microsoft.com/online/cpim/schemas/2013/06"
  PolicySchemaVersion="0.3.0.0"
  TenantId="your-tenant.partner.onmschina.cn"
  PolicyId="B2C_1A_signup_signin"
  PublicPolicyUri="http://your-tenant.partner.onmschina.cn/B2C_1A_signup_signin">

  <BasePolicy>
    <TenantId>your-tenant.partner.onmschina.cn</TenantId>
    <PolicyId>B2C_1A_TrustFrameworkExtensions</PolicyId>
  </BasePolicy>

  <RelyingParty>
    <DefaultUserJourney ReferenceId="SignUpOrSignIn" />
    <UserJourneyBehaviors>
      <SingleSignOn Scope="Tenant" KeepAliveInDays="7"/>
      <SessionExpiryType>Rolling</SessionExpiryType>
      <SessionExpiryInSeconds>900</SessionExpiryInSeconds>
      <JourneyInsights TelemetryEngine="ApplicationInsights" InstrumentationKey="your-application-insights-key" DeveloperMode="true" ClientEnabled="false" ServerEnabled="true" TelemetryVersion="1.0.0" />
      <ContentDefinitionParameters>
        <Parameter Name="campaignId">{OAUTH-KV:campaignId}</Parameter>
      </ContentDefinitionParameters>
    </UserJourneyBehaviors>
    <TechnicalProfile Id="PolicyProfile">
      <DisplayName>PolicyProfile</DisplayName>
      <Description>The policy profile</Description>
      <Protocol Name="OpenIdConnect" />
      <Metadata>collection of key/value pairs of data</Metadata>
      <OutputClaims>
        <OutputClaim ClaimTypeReferenceId="displayName" />
        <OutputClaim ClaimTypeReferenceId="givenName" />
        <OutputClaim ClaimTypeReferenceId="surname" />
        <OutputClaim ClaimTypeReferenceId="email" />
        <OutputClaim ClaimTypeReferenceId="objectId" PartnerClaimType="sub"/>
        <OutputClaim ClaimTypeReferenceId="identityProvider" />
        <OutputClaim ClaimTypeReferenceId="loyaltyNumber" />
      </OutputClaims>
      <SubjectNamingInfo ClaimType="sub" />
    </TechnicalProfile>
  </RelyingParty>
  ...

可选 RelyingParty 元素包含下列元素:

元素 出现次数 说明
DefaultUserJourney 1:1 信赖方应用的默认用户旅程。
终结点 0:1 终结点的列表。 有关详细信息,请参阅 UserInfo 终结点
UserJourneyBehaviors 0:1 用户旅程行为的范围。
TechnicalProfile 1:1 信赖方应用支持的技术配置文件。 该技术配置文件提供了信赖方应用与 Azure AD B2C 联系的协定。

需要按照上表中显示的顺序创建 RelyingParty 子元素。

终结点

Endpoints 元素包含以下元素:

元素 出现次数 说明
端点 1:1 对终结点的引用。

Endpoint 元素包含以下属性:

属性 必须 描述
ID 终结点的唯一标识符。
UserJourneyReferenceId 策略中用户旅程的标识符。 有关详细信息,请参阅用户旅程

以下示例显示了具有 UserInfo 终结点的信赖方:

<RelyingParty>
  <DefaultUserJourney ReferenceId="SignUpOrSignIn" />
  <Endpoints>
    <Endpoint Id="UserInfo" UserJourneyReferenceId="UserInfoJourney" />
  </Endpoints>
  ...

DefaultUserJourney

DefaultUserJourney 元素指定对在基本或扩展策略中定义的用户旅程标识符的引用。 下面的示例演示在 RelyingParty 元素中指定的注册或登录用户旅程:

B2C_1A_signup_signin 策略:

<RelyingParty>
  <DefaultUserJourney ReferenceId="SignUpOrSignIn">
  ...

B2C_1A_TrustFrameWorkBase 或 B2C_1A_TrustFrameworkExtensionPolicy:

<UserJourneys>
  <UserJourney Id="SignUpOrSignIn">
  ...

DefaultUserJourney 元素包含以下属性:

属性 必须 说明
ReferenceId 策略中用户旅程的标识符。 有关详细信息,请参阅用户旅程

UserJourneyBehaviors

UserJourneyBehaviors 元素包含下列元素:

元素 出现次数 说明
SingleSignOn 0:1 用户旅程单一登录 (SSO) 会话行为的范围。
SessionExpiryType 0:1 会话的身份验证行为。 可能的值:RollingAbsoluteRolling 值(默认值)表示用户保持登录状态,只要用户在应用程序中保持持续活动状态。 Absolute 值指示在应用程序会话生命周期指定的时间段后将强制用户重新进行身份验证。
SessionExpiryInSeconds 0:1 身份验证成功后,存储在用户浏览器上指定为整数的 Azure AD B2C 会话 Cookie 的生存期。 默认值为 86,400 秒(24 小时)。 最小值为 900 秒(15 分钟)。 最大值为 86,400 秒(24 小时)。
JourneyInsights 0:1 要使用的 Azure Application Insights 检测密钥。
ContentDefinitionParameters 0:1 要追加到内容定义负载 URI 的键值对列表。
JourneyFraming 0:1 允许在 iframe 中加载此策略的用户界面。
ScriptExecution 0:1 支持的 JavaScript 执行模式。 可能的值:AllowDisallow(默认值)。

使用上述元素时,需要按照表中指定的顺序将它们添加到 UserJourneyBehaviors 元素中。 例如,JourneyInsights 元素必须添加在 ScriptExecution 元素之前(之上)。

SingleSignOn

SingleSignOn 元素包含以下特性:

属性 必须 说明
作用域 单一登录行为的范围。 可能的值:SuppressedTenantApplicationPolicySuppressed 值指示禁止此行为,并且系统会始终提示用户选择标识提供者。 Tenant 值指示该行为适用于租户中的所有策略。 例如,不会提示在两个策略旅程中导航租户的用户选择标识提供者。 Application 值指示该行为适用于发出请求的应用程序的所有策略。 例如,不会提示在应用程序的两个策略旅程中导航的用户选择标识提供者。 Policy 值指示该行为仅适用于一个策略。 例如,当在策略之间切换时,会提示在两个策略旅程中导航信任框架的用户选择标识提供者。
KeepAliveInDays 控制用户保持登录状态的时间长短。 将此值设置为 0 会关闭 KMSI 功能。 默认值为 0(禁用)。 最小值为 1 天。 最大值为 90 天。 有关详细信息,请参阅使我保持登录状态
EnforceIdTokenHintOnLogout 强制将以前颁发的 ID 令牌传递到注销终结点,作为最终用户当前与客户端进行的身份验证会话的提示。 可能的值为 false(默认)或 true。 有关详细信息,请参阅使用 OpenID Connect 进行 Web 登录

JourneyInsights

JourneyInsights 元素包含以下属性:

属性 必须 说明
TelemetryEngine 值必须是 ApplicationInsights
InstrumentationKey 一个字符串,其中包含 application insights 元素的检测密钥。
DeveloperMode 可能的值:truefalse。 如果是 true,Application Insights 将加快遥测数据通过处理管道。 此设置适用于开发,但在高容量时受到限制。 详细活动日志仅设计用来帮助开发自定义策略。 请勿在生产中使用开发模式。 日志收集在开发过程中发送到标识提供者以及从中发出的所有声明。 如果在生产中使用,则开发人员对他们所拥有的 App Insights 日志中收集的个人数据负责。 只有当该值设置为 true,才会收集这些详细日志。
ClientEnabled 可能的值:truefalse。 如果是 true,则发送用于跟踪页面视图和客户端错误的 Application Insights 客户端脚本。
ServerEnabled 可能的值:truefalse。 如果是 true,则将现有 UserJourneyRecorder JSON 作为自定义事件发送到 Application Insights。
TelemetryVersion 值必须是 1.0.0

有关详细信息,请参阅收集日志

ContentDefinitionParameters

在 Azure AD B2C 中使用自定义策略可在查询字符串中发送参数。 通过将该参数传递到 HTML 终结点,可以动态更改页面内容。 例如,可以基于从 Web 或移动应用程序传递的参数,更改 Azure AD B2C 注册或登录页面上的背景图像。 Azure AD B2C 向动态 HTML 文件传递查询字符串参数,例如 aspx 文件。

下面的示例传递名为 campaignId 的参数,查询字符串中的值为 hawaii

https://login.microsoft.com/contoso.partner.onmschina.cn/oauth2/v2.0/authorize?pB2C_1A_signup_signin&client_id=a415078a-0402-4ce3-a9c6-ec1947fcfb3f&nonce=defaultNonce&redirect_uri=http%3A%2F%2Fjwt.io%2F&scope=openid&response_type=id_token&prompt=login&campaignId=hawaii

ContentDefinitionParameters 元素包含以下元素:

元素 出现次数 说明
ContentDefinitionParameter 0:n 一个字符串,包含追加到内容定义负载 URI 查询字符串的键值对。

ContentDefinitionParameters 元素包含以下属性:

属性 必须 说明
客户 键值对的名称。

有关详细信息,请参阅使用自定义策略配置包含动态内容的 UI

JourneyFraming

JourneyFraming 元素包含以下特性:

属性 必须 说明
已启用 允许在 iframe 中加载此策略。 可能的值为 false(默认)或 true
包含将加载托管 iframe 的域。

TechnicalProfile

TechnicalProfile 元素包含以下属性:

Attribute 必须 描述
ID 值必须是 PolicyProfile

TechnicalProfile 包含以下元素:

元素 出现次数 说明
DisplayName 1:1 一个字符串,其中包含技术配置文件的名称。
说明 0:1 一个字符串,其中包含技术配置文件的说明。
协议 1:1 用于联合的协议。
Metadata 0:1 一个键/值对项集合,由协议在事务过程中与终结点进行通信,以配置依赖方与其他社区参与者之间的交互。
InputClaims 1:1 作为技术配置文件中的输入的声明类型列表。 这些元素中的每一个都包含对已在 ClaimsSchema 部分或策略文件继承自的策略中定义的 ClaimType。
OutputClaims 1:1 作为技术配置文件中的输出的声明类型列表。 这些元素中的每一个都包含对已在 ClaimsSchema 部分或策略文件继承自的策略中定义的 ClaimType。
SubjectNamingInfo 1:1 在令牌中使用的使用者名称。

Protocol 元素包含以下属性:

属性 必须 说明
客户 Azure AD B2C 支持的有效协议的名称,用作技术配置文件的一部分。 可能的值:OpenIdConnectSAML2OpenIdConnect 值表示根据 OpenID 基本规范的 OpenID Connect 1.0 协议标准。 SAML2 表示根据 OASIS 规范的 SAML 2.0 协议标准。

Metadata

如果协议是 SAML,则元数据元素包含以下元素。 有关详细信息,请参阅用于在 Azure AD B2C 中注册 SAML 应用程序的选项

属性 必须 说明
IdpInitiatedProfileEnabled 指示是否支持 IDP 发起的流。 可能的值:truefalse(默认值)。
XmlSignatureAlgorithm Azure AD B2C 用于对 SAML 响应进行签名的方法。 可能的值:Sha256Sha384Sha512Sha1。 确保在两端配置具有相同值的签名算法。 仅使用证书支持的算法。 若要配置 SAML 断言,请参阅 SAML 颁发者技术配置文件元数据
DataEncryptionMethod 指示 Azure AD B2C 在使用高级加密标准 (AES) 算法时用来加密数据的方法。 此元数据控制 SAML 响应中 <EncryptedData> 元素的值。 可能的值:Aes256(默认值)、Aes192Sha512 Aes128
KeyEncryptionMethod 指示 Azure AD B2C 对用来加密数据的密钥副本进行加密时使用的方法。 此元数据控制 SAML 响应中 <EncryptedKey> 元素的值。 可能的值: Rsa15(默认值)- RSA 公钥加密标准 (PKCS) 版本 1.5 算法; RsaOaep - RSA 最佳非对称加密填充 (OAEP) 加密算法。
UseDetachedKeys 可能的值:truefalse(默认值)。 如果将值设置为 true,则 Azure AD B2C 会更改已加密断言的格式。 使用分离的密钥会将加密的断言添加为 EncrytedAssertion 的子元素而不是 EncryptedData 的子元素。
WantsSignedResponses 指示 Azure AD B2C 是否对 SAML 响应的 Response 部分进行签名。 可能的值:true(默认值)或 false
RemoveMillisecondsFromDateTime 指示是否将从 SAML 响应中的日期/时间值(包括 IssueInstant、NotBefore、NotOnOrAfter 和 AuthnInstant)中删除毫秒值。 可能的值:false(默认值)或 true
RequestContextMaximumLengthInBytes 指示 SAML 应用程序RelayState 参数的最大长度。 默认值为 1000。 最大值为 2048。

InputClaims

InputClaims 元素包含以下元素:

元素 出现次数 说明
InputClaim 0:n 预期的输入声明类型。

InputClaim 元素包含以下属性:

Attribute 必须 说明
ClaimTypeReferenceId 对在策略文件的 ClaimsSchema 部分定义的 ClaimType 的引用。
DefaultValue 一个默认值,如果声明值为空,则可以使用该值。
PartnerClaimType 按照 ClaimType 定义中配置的不同名称发送声明。

OutputClaims

OutputClaims 元素包含以下元素:

元素 出现次数 说明
OutputClaim 0:n 信赖方订阅的策略中受支持列表的预期声明类型的名称。 此声明可作为技术配置文件输出。

OutputClaim 元素包含以下属性:

Attribute 必须 说明
ClaimTypeReferenceId 对在策略文件的 ClaimsSchema 部分定义的 ClaimType 的引用。
DefaultValue 一个默认值,如果声明值为空,则可以使用该值。
PartnerClaimType 按照 ClaimType 定义中配置的不同名称发送声明。

SubjectNamingInfo

通过 SubjectNamingInfo 元素,可以控制令牌使用者的值:

  • JWT 令牌 - sub 声明。 这是令牌针对其断言信息的主体,例如应用程序的用户。 此值固定不变,无法重新分配或重复使用。 可使用它安全地执行授权检查,例如,使用令牌访问资源时。 默认情况下,将使用目录中用户的对象 ID 填充使用者声明。 有关详细信息,请参阅令牌、会话和单一登录配置
  • SAML 令牌 - 标识使用者元素的 <Subject><NameID> 元素。 可以修改 NameId 格式。

SubjectNamingInfo 元素包含以下属性:

属性 必须 说明
ClaimType 对输出声明的 PartnerClaimType 的引用。 输出声明必须在使用 PartnerClaimType 的信赖方策略 OutputClaims 集合中定义。 例如,<OutputClaim ClaimTypeReferenceId="objectId" PartnerClaimType="sub" /><OutputClaim ClaimTypeReferenceId="signInName" PartnerClaimType="signInName" />
格式 用于 SAML 依赖方,以设置 SAML 断言中返回的 NameId 格式。

下面的示例演示如何定义 OpenID Connect 信赖方。 使用者名称信息配置为 objectId

<RelyingParty>
  <DefaultUserJourney ReferenceId="SignUpOrSignIn" />
  <TechnicalProfile Id="PolicyProfile">
    <DisplayName>PolicyProfile</DisplayName>
    <Protocol Name="OpenIdConnect" />
    <OutputClaims>
      <OutputClaim ClaimTypeReferenceId="displayName" />
      <OutputClaim ClaimTypeReferenceId="givenName" />
      <OutputClaim ClaimTypeReferenceId="surname" />
      <OutputClaim ClaimTypeReferenceId="email" />
      <OutputClaim ClaimTypeReferenceId="objectId" PartnerClaimType="sub"/>
      <OutputClaim ClaimTypeReferenceId="identityProvider" />
    </OutputClaims>
    <SubjectNamingInfo ClaimType="sub" />
  </TechnicalProfile>
</RelyingParty>

JWT 令牌包括带用户 objectId 的 sub 声明:

{
  ...
  "sub": "6fbbd70d-262b-4b50-804c-257ae1706ef2",
  ...
}

下面的示例演示如何定义 SAML 信赖方。 主体名称信息配置为 objectId,并提供了 NameId format

<RelyingParty>
  <DefaultUserJourney ReferenceId="SignUpOrSignIn" />
  <TechnicalProfile Id="PolicyProfile">
    <DisplayName>PolicyProfile</DisplayName>
    <Protocol Name="SAML2" />
    <OutputClaims>
      <OutputClaim ClaimTypeReferenceId="displayName" />
      <OutputClaim ClaimTypeReferenceId="givenName" />
      <OutputClaim ClaimTypeReferenceId="surname" />
      <OutputClaim ClaimTypeReferenceId="email" />
      <OutputClaim ClaimTypeReferenceId="objectId" PartnerClaimType="sub"/>
      <OutputClaim ClaimTypeReferenceId="identityProvider" />
    </OutputClaims>
    <SubjectNamingInfo ClaimType="sub" Format="urn:oasis:names:tc:SAML:2.0:nameid-format:transient"/>
  </TechnicalProfile>
</RelyingParty>