你当前正在访问 Microsoft Azure Global Edition 技术文档网站。 如果需要访问由世纪互联运营的 Microsoft Azure 中国技术文档网站,请访问 https://docs.azure.cn。
字符串声明转换
本文演示了在 Azure Active Directory B2C (Azure AD B2C) 中使用 Identity Experience Framework 架构的字符串声明转换的过程。 有关详细信息,请参阅声明转换。
AssertStringClaimsAreEqual
比较两个声明,如果根据指定的比较 inputClaim1、inputClaim2 和 stringComparison 确定它们不相等,将引发异常。
查看此声明转换的实时演示。
元素 | TransformationClaimType | 数据类型 | 说明 |
---|---|---|---|
InputClaim | inputClaim1 | 字符串 | 要比较的第一个声明的类型。 |
InputClaim | inputClaim2 | string | 要比较的第二个声明的类型。 |
InputParameter | stringComparison | 字符串 | 字符串比较,值为下列其中一项:Ordinal、OrdinalIgnoreCase。 |
AssertStringClaimsAreEqual 声明转换始终从一个验证技术配置文件执行,该文件由自断言技术配置文件或 DisplayControl 调用。 自断言技术配置文件的 UserMessageIfClaimsTransformationStringsAreNotEqual
元数据控制向用户显示的错误消息。 可以将错误消息本地化。
AssertStringClaimsAreEqual 示例
可以使用此声明转换来确保两个声明具有相同的值。 如果没有,则会引发错误消息。 以下示例检查 strongAuthenticationEmailAddress 声明是否等同于 email 声明, 否则会引发错误消息。
<ClaimsTransformation Id="AssertEmailAndStrongAuthenticationEmailAddressAreEqual" TransformationMethod="AssertStringClaimsAreEqual">
<InputClaims>
<InputClaim ClaimTypeReferenceId="strongAuthenticationEmailAddress" TransformationClaimType="inputClaim1" />
<InputClaim ClaimTypeReferenceId="email" TransformationClaimType="inputClaim2" />
</InputClaims>
<InputParameters>
<InputParameter Id="stringComparison" DataType="string" Value="ordinalIgnoreCase" />
</InputParameters>
</ClaimsTransformation>
- 输入声明:
- inputClaim1: someone@contoso.com
- inputClaim2: someone@outlook.com
- 输入参数:
- stringComparison: ordinalIgnoreCase
- 结果:引发错误
调用 AssertStringClaimsAreEqual 声明转换
login-NonInteractive 验证技术配置文件调用 AssertEmailAndStrongAuthenticationEmailAddressAreEqual 声明转换。
<TechnicalProfile Id="login-NonInteractive">
...
<OutputClaimsTransformations>
<OutputClaimsTransformation ReferenceId="AssertEmailAndStrongAuthenticationEmailAddressAreEqual" />
</OutputClaimsTransformations>
</TechnicalProfile>
自断言技术配置文件调用验证 login-NonInteractive 技术配置文件。
<TechnicalProfile Id="SelfAsserted-LocalAccountSignin-Email">
<Metadata>
<Item Key="UserMessageIfClaimsTransformationStringsAreNotEqual">Custom error message the email addresses you provided are not the same.</Item>
</Metadata>
<ValidationTechnicalProfiles>
<ValidationTechnicalProfile ReferenceId="login-NonInteractive" />
</ValidationTechnicalProfiles>
</TechnicalProfile>
BuildUri
创建基于时间的一次性密码 (TOTP) URI。 URI 是用户的唯一标识符(例如电子邮件地址和密钥)的组合。 URI 稍后将转换为向用户呈现的 QR 码。 查看此声明转换的实时演示。
元素 | TransformationClaimType | 数据类型 | 说明 |
---|---|---|---|
InputClaim | path | string | 用户的唯一标识符,例如电子邮件地址、用户名或电话号码。 |
InputClaim | query.secret | 字符串 | TOTP 密钥。 |
InputParameter | scheme | 字符串 | URI 的方案部分。 例如,otpauth 。 |
InputParameter | host | string | URI 的方案部分。 例如,totp 。 |
InputParameter | query.issuer | 字符串 | URI 的颁发者部分。 例如,{AuthenticatorIssuer} 。 |
OutputClaim | outputClaim | 字符串 | 调用此声明转换后生成的声明。 |
BuildUri 示例
以下声明转换可生成一个 TOTP URI,它随后将在 QR 码或深层链接中显示。
<ClaimsTransformation Id="CreateUriString" TransformationMethod="BuildUri">
<InputClaims>
<InputClaim ClaimTypeReferenceId="uriLabel" TransformationClaimType="path" />
<InputClaim ClaimTypeReferenceId="secretKey" TransformationClaimType="query.secret" />
</InputClaims>
<InputParameters>
<InputParameter Id="scheme" DataType="string" Value="otpauth" />
<InputParameter Id="host" DataType="string" Value="totp" />
<InputParameter Id="query.issuer" DataType="string" Value="{AuthenticatorIssuer}" />
</InputParameters>
<OutputClaims>
<OutputClaim ClaimTypeReferenceId="qrCodeContent" TransformationClaimType="outputClaim" />
</OutputClaims>
</ClaimsTransformation>
- 输入声明:
- path: emily@fabrikam.com
- query.secret:
fay2lj7ynpntjgqa
- 输入参数:
- scheme:
otpauth
- host:
totp
- query.issuer:
{AuthenticatorIssuer}
- scheme:
- 输出声明:
- outputClaim:
otpauth://totp/Contoso%20demo:emily@fabrikam.com?secret=fay2lj7ynpntjgqa&issuer=Contoso+demo
- outputClaim:
ChangeCase
将所提供的声明更改为小写或大写,具体要取决于运算符。 查看此声明转换的实时演示。
元素 | TransformationClaimType | 数据类型 | 说明 |
---|---|---|---|
InputClaim | inputClaim1 | 字符串 | 要更改的声明。 |
InputParameter | toCase | 字符串 | 以下值之一:LOWER 或 UPPER 。 |
OutputClaim | outputClaim | 字符串 | 调用此声明转换后生成的声明。 |
ChangeCase 示例
以下声明转换将 email 声明更改为小写。
<ClaimsTransformation Id="ChangeToLower" TransformationMethod="ChangeCase">
<InputClaims>
<InputClaim ClaimTypeReferenceId="email" TransformationClaimType="inputClaim1" />
</InputClaims>
<InputParameters>
<InputParameter Id="toCase" DataType="string" Value="LOWER" />
</InputParameters>
<OutputClaims>
<OutputClaim ClaimTypeReferenceId="email" TransformationClaimType="outputClaim" />
</OutputClaims>
</ClaimsTransformation>
- 输入声明:
- email: SomeOne@contoso.com
- 输入参数:
- toCase:LOWER
- 输出声明:
- email: someone@contoso.com
CompareClaims
确定一个字符串声明是否等于另一个字符串声明。 结果是新布尔型声明,值为 true
或 false
。 查看此声明转换的实时演示。
元素 | TransformationClaimType | 数据类型 | 说明 |
---|---|---|---|
InputClaim | inputClaim1 | 字符串 | 要比较的第一个声明类型。 |
InputClaim | inputClaim2 | 字符串 | 要比较的第二个声明类型。 |
InputParameter | 运算符后的表达式 | 字符串 | 可能的值:EQUAL 或 NOT EQUAL 。 |
InputParameter | ignoreCase | string | 指定此比较是否应忽略所比较字符串的大小写。 |
OutputClaim | outputClaim | boolean | 调用此声明转换后生成的声明。 |
CompareClaims 示例
使用此声明转换检查一个声明是否等于另一个声明。 以下声明转换检查 email 声明的值是否等于 Verified.Email 声明的值。
<ClaimsTransformation Id="CheckEmail" TransformationMethod="CompareClaims">
<InputClaims>
<InputClaim ClaimTypeReferenceId="Email" TransformationClaimType="inputClaim1" />
<InputClaim ClaimTypeReferenceId="Verified.Email" TransformationClaimType="inputClaim2" />
</InputClaims>
<InputParameters>
<InputParameter Id="operator" DataType="string" Value="NOT EQUAL" />
<InputParameter Id="ignoreCase" DataType="string" Value="true" />
</InputParameters>
<OutputClaims>
<OutputClaim ClaimTypeReferenceId="SameEmailAddress" TransformationClaimType="outputClaim" />
</OutputClaims>
</ClaimsTransformation>
- 输入声明:
- inputClaim1: someone@contoso.com
- inputClaim2: someone@outlook.com
- 输入参数:
- operator:NOT EQUAL
- ignoreCase: true
- 输出声明:
- outputClaim: true
CompareClaimToValue
确定声明值是否等于输入参数值。 查看此声明转换的实时演示。
元素 | TransformationClaimType | 数据类型 | 说明 |
---|---|---|---|
InputClaim | inputClaim1 | 字符串 | 要比较的声明类型。 |
InputParameter | 运算符后的表达式 | 字符串 | 可能的值:EQUAL 或 NOT EQUAL 。 |
InputParameter | compareTo | string | 字符串比较,其中一个值,即输入声明值必须与之比较的字符串:Ordinal、OrdinalIgnoreCase。 |
InputParameter | ignoreCase | string | 指定此比较是否应忽略所比较字符串的大小写。 |
OutputClaim | outputClaim | boolean | 调用此声明转换后生成的声明。 |
CompareClaimToValue 示例
可以使用此声明转换检查一个声明是否等于指定的值。 例如,以下声明转换将检查 termsOfUseConsentVersion 声明的值是否等于 V2
。
<ClaimsTransformation Id="IsTermsOfUseConsentRequiredForVersion" TransformationMethod="CompareClaimToValue">
<InputClaims>
<InputClaim ClaimTypeReferenceId="termsOfUseConsentVersion" TransformationClaimType="inputClaim1" />
</InputClaims>
<InputParameters>
<InputParameter Id="compareTo" DataType="string" Value="V2" />
<InputParameter Id="operator" DataType="string" Value="NOT EQUAL" />
<InputParameter Id="ignoreCase" DataType="string" Value="true" />
</InputParameters>
<OutputClaims>
<OutputClaim ClaimTypeReferenceId="termsOfUseConsentRequired" TransformationClaimType="outputClaim" />
</OutputClaims>
</ClaimsTransformation>
- 输入声明:
- inputClaim1: v1
- 输入参数:
- compareTo:V2
- operator:NOT EQUAL
- ignoreCase: true
- 输出声明:
- outputClaim: true
CopyClaimIfPredicateMatch
如果输入声明的值与输出声明谓词匹配,则将一个声明的值复制到另一个。 查看此声明转换的实时演示。
元素 | TransformationClaimType | 数据类型 | 说明 |
---|---|---|---|
InputClaim | inputClaim | 字符串 | 要复制的声明类型。 |
OutputClaim | outputClaim | 字符串 | 调用此声明转换后生成的声明类型。 根据此声明谓词检查输入声明的值。 |
CopyClaimIfPredicateMatch 示例
以下示例尝试将 signInName 声明值复制到 phoneNumber 声明。 在此示例中,不会复制该值。 signInName 声明未采用预期格式的电话号码。 有关完整的示例,请参阅电话号码或电子邮件登录初学者包策略。
<ClaimsTransformation Id="SetPhoneNumberIfPredicateMatch" TransformationMethod="CopyClaimIfPredicateMatch">
<InputClaims>
<InputClaim ClaimTypeReferenceId="signInName" TransformationClaimType="inputClaim" />
</InputClaims>
<OutputClaims>
<OutputClaim ClaimTypeReferenceId="phoneNumber" TransformationClaimType="outputClaim" />
</OutputClaims>
</ClaimsTransformation>
- 输入声明:
- inputClaim: bob@contoso.com
- 输出声明:
- outputClaim:不会更改输出声明的原始值。
与谓词匹配的 CopyClaimIfPredicateMatch 示例
此示例中,声明转换将复制值。 signInName 声明采用正确格式的电话号码。
- 输入声明:
- inputClaim:+11234567890
- 输出声明:
- outputClaim:+11234567890
CreateOtpSecret
创建 TOTP 字符串声明。 此声明转换的输出是一个 TOTP 机密,该机密随后存储在 Azure Ad B2C 用户的帐户中,并与 Microsoft Authenticator 应用共享。 当用户需要进行 MFA 时,验证器应用使用该密钥生成 TOTP 代码。 你的策略使用此密钥来验证用户提供的 TOTP 代码。
查看此声明转换的实时演示。
元素 | TransformationClaimType | 数据类型 | 说明 |
---|---|---|---|
OutputClaim | outputClaim | 字符串 | 使用生成的 TOTP 代码调用此声明转换后生成的声明。 |
CreateOtpSecret 示例
以下声明转换为 TOTP 多重身份验证器创建机密。
<ClaimsTransformation Id="CreateSecret" TransformationMethod="CreateOtpSecret">
<OutputClaims>
<OutputClaim ClaimTypeReferenceId="secretKey" TransformationClaimType="outputClaim" />
</OutputClaims>
</ClaimsTransformation>
- 输出声明:
- outputClaim:
hmlcmd4ph6fph64c
- outputClaim:
CreateRandomString
使用随机数生成器创建随机字符串。 如果随机数生成器是 integer
类型,则可以选择提供种子参数和最大数。 可选字符串格式参数允许使用它来格式化输出,可选的 base64 参数指定输出是否为 base64 编码的 encoded randomGeneratorType [guid, integer] outputClaim(字符串)。
查看此声明转换的实时演示。
元素 | TransformationClaimType | 数据类型 | 说明 |
---|---|---|---|
InputParameter | randomGeneratorType | 字符串 | 指定要生成的随机值,GUID (全局唯一 ID)或 INTEGER (数字)。 |
InputParameter | stringFormat | 字符串 | [可选]格式化随机值。 |
InputParameter | base64 | boolean | [可选]将随机值转换为 base64。 如果应用字符串格式,则字符串格式之后的值将被编码为 base64。 |
InputParameter | maximumNumber | int | [可选]仅限 INTEGER randomGeneratorType。 指定最大数。 |
InputParameter | seed | int | [可选]仅限 INTEGER randomGeneratorType。 指定随机值的种子。 注意:同一个种子生成相同的随机数字序列。 |
OutputClaim | outputClaim | 字符串 | 调用此声明转换后将生成的声明。 随机值。 |
CreateRandomString 示例
下面的示例将生成全局唯一 ID。 此声明转换用于创建随机 UPN(用户主体名称)。
<ClaimsTransformation Id="CreateRandomUPNUserName" TransformationMethod="CreateRandomString">
<InputParameters>
<InputParameter Id="randomGeneratorType" DataType="string" Value="GUID" />
</InputParameters>
<OutputClaims>
<OutputClaim ClaimTypeReferenceId="upnUserName" TransformationClaimType="outputClaim" />
</OutputClaims>
</ClaimsTransformation>
- 输入参数:
- randomGeneratorType:GUID
- 输出声明:
- outputClaim: bc8bedd2-aaa3-411e-bdee-2f1810b73dfc
创建数值的 CreateRandomString 示例
下面的示例生成 0 到 1000 之间的随机整数值。 值被格式化为 OTP_{random value}。
<ClaimsTransformation Id="SetRandomNumber" TransformationMethod="CreateRandomString">
<InputParameters>
<InputParameter Id="randomGeneratorType" DataType="string" Value="INTEGER" />
<InputParameter Id="maximumNumber" DataType="int" Value="1000" />
<InputParameter Id="stringFormat" DataType="string" Value="OTP_{0}" />
<InputParameter Id="base64" DataType="boolean" Value="false" />
</InputParameters>
<OutputClaims>
<OutputClaim ClaimTypeReferenceId="randomNumber" TransformationClaimType="outputClaim" />
</OutputClaims>
</ClaimsTransformation>
- 输入参数:
- randomGeneratorType:INTEGER
- maximumNumber:1000
- stringFormat:OTP_{0}
- base64: false
- 输出声明:
- outputClaim:OTP_853
CreateStringClaim
基于转换中提供的输入参数创建字符串声明。 查看此声明转换的实时演示。
元素 | TransformationClaimType | 数据类型 | 说明 |
---|---|---|---|
InputParameter | 值 | 字符串 | 要设置的字符串。 此输入参数支持字符串声明转换表达式。 |
OutputClaim | createdClaim | 字符串 | 调用此声明转换后生成的声明,其值在输入参数中指定。 |
CreateStringClaim 示例
以下声明转换创建一个包含服务条款的字符串值。
<ClaimsTransformation Id="CreateTermsOfService" TransformationMethod="CreateStringClaim">
<InputParameters>
<InputParameter Id="value" DataType="string" Value="Contoso terms of service..." />
</InputParameters>
<OutputClaims>
<OutputClaim ClaimTypeReferenceId="TOS" TransformationClaimType="createdClaim" />
</OutputClaims>
</ClaimsTransformation>
- 输入参数:
- value:Contoso 服务条款...
- 输出声明:
- createdClaim:TOS 声明包含“Contoso 服务条款…”值。
FormatLocalizedString
根据提供的本地化格式字符串来格式化多个声明。 此转换将使用 C# String.Format
方法。 查看此声明转换的实时演示。
元素 | TransformationClaimType | 数据类型 | 注释 |
---|---|---|---|
InputClaims | 字符串 | 充当字符串格式 {0}、{1}、{2} 参数的输入声明的集合。 | |
InputParameter | stringFormatId | 字符串 | 本地化字符串的 StringId 。 |
OutputClaim | outputClaim | 字符串 | 调用此声明转换后生成的声明。 |
注意
可以指定的输入声明数没有限制,但格式化字符串的最大长度为 4000。
若要使用 FormatLocalizedString 声明转换:
- 定义本地化字符串,并将其与 self-asserted-technical-profile 相关联。
LocalizedString
元素的ElementType
必须设为FormatLocalizedStringTransformationClaimType
。StringId
是定义的唯一标识符,稍后会用于声明转换stringFormatId
。- 在声明转换中,指定要使用本地化字符串设置的声明列表。 然后,将
stringFormatId
设置为本地字符串元素的StringId
。 - 在自我断言技术配置文件或显示控制输入或输出声明转换中引用你的声明转换。
FormatLocalizedString 示例
当帐户已经在目录中时,下面的示例将生成一条错误消息。 该示例针对英语(默认)和西班牙语定义了本地化字符串。
<Localization Enabled="true">
<SupportedLanguages DefaultLanguage="en" MergeBehavior="Append">
<SupportedLanguage>en</SupportedLanguage>
<SupportedLanguage>es</SupportedLanguage>
</SupportedLanguages>
<LocalizedResources Id="api.localaccountsignup.en">
<LocalizedStrings>
<LocalizedString ElementType="FormatLocalizedStringTransformationClaimType" StringId="ResponseMessge_EmailExists">The email '{0}' is already an account in this organization. Click Next to sign in with that account.</LocalizedString>
</LocalizedStrings>
</LocalizedResources>
<LocalizedResources Id="api.localaccountsignup.es">
<LocalizedStrings>
<LocalizedString ElementType="FormatLocalizedStringTransformationClaimType" StringId="ResponseMessge_EmailExists">Este correo electrónico "{0}" ya es una cuenta de esta organización. Haga clic en Siguiente para iniciar sesión con esa cuenta.</LocalizedString>
</LocalizedStrings>
</LocalizedResources>
</Localization>
声明转换基于本地化的字符串创建响应消息。 此消息包含嵌入到本地化字符串 ResponseMessge_EmailExists 中的用户电子邮件地址。
<ClaimsTransformation Id="SetResponseMessageForEmailAlreadyExists" TransformationMethod="FormatLocalizedString">
<InputClaims>
<InputClaim ClaimTypeReferenceId="email" />
</InputClaims>
<InputParameters>
<InputParameter Id="stringFormatId" DataType="string" Value="ResponseMessge_EmailExists" />
</InputParameters>
<OutputClaims>
<OutputClaim ClaimTypeReferenceId="responseMsg" TransformationClaimType="outputClaim" />
</OutputClaims>
</ClaimsTransformation>
- 输入声明:
- inputClaim: sarah@contoso.com
- 输入参数:
- stringFormat:ResponseMessge_EmailExists
- 输出声明:
- outputClaim:电子邮件地址“sarah@contoso.com”已是此组织中的帐户。 选择“下一步”,使用该帐户进行登录。
FormatStringClaim
根据提供的格式字符串格式化声明。 此转换将使用 C# String.Format
方法。 查看此声明转换的实时演示。
元素 | TransformationClaimType | 数据类型 | 说明 |
---|---|---|---|
InputClaim | inputClaim | 字符串 | 作为字符串格式 {0} 参数的声明。 |
InputParameter | stringFormat | 字符串 | 字符串格式,包括 {0} 参数。 此输入参数支持字符串声明转换表达式。 |
OutputClaim | outputClaim | 字符串 | 调用此声明转换后生成的声明。 |
注意
允许的字符串格式最大大小为 4000。
FormatStringClaim 示例
使用此声明转换格式化任何带一个参数 {0} 的字符串。 以下示例创建一个 userPrincipalName。 所有社交标识提供者技术配置文件(如 Facebook-OAUTH
)都调用 CreateUserPrincipalName 来生成 userPrincipalName。
<ClaimsTransformation Id="CreateUserPrincipalName" TransformationMethod="FormatStringClaim">
<InputClaims>
<InputClaim ClaimTypeReferenceId="upnUserName" TransformationClaimType="inputClaim" />
</InputClaims>
<InputParameters>
<InputParameter Id="stringFormat" DataType="string" Value="cpim_{0}@{RelyingPartyTenantId}" />
</InputParameters>
<OutputClaims>
<OutputClaim ClaimTypeReferenceId="userPrincipalName" TransformationClaimType="outputClaim" />
</OutputClaims>
</ClaimsTransformation>
- 输入声明:
- inputClaim:5164db16-3eee-4629-bfda-dcc3326790e9
- 输入参数:
- stringFormat:cpim_{0}@{RelyingPartyTenantId}
- 输出声明:
- outputClaim: cpim_5164db16-3eee-4629-bfda-dcc3326790e9@b2cdemo.onmicrosoft.com
FormatStringMultipleClaims
根据提供的格式字符串格式化两个声明。 此转换将使用 C# String.Format
方法。 查看此声明转换的实时演示。
元素 | TransformationClaimType | 数据类型 | 说明 |
---|---|---|---|
InputClaim | inputClaim1 | 字符串 | 作为字符串格式 {0} 参数的声明。 |
InputClaim | inputClaim2 | 字符串 | 作为字符串格式 {1} 参数的声明。 |
InputParameter | stringFormat | 字符串 | 字符串格式,包括 {0} 和 {1} 参数。 此输入参数支持字符串声明转换表达式。 |
OutputClaim | outputClaim | 字符串 | 调用此声明转换后生成的声明。 |
注意
允许的字符串格式最大大小为 4000。
FormatStringMultipleClaims 示例
使用此声明转换格式化任何带两个参数 {0} 和 {1} 的字符串。 下面的示例创建带指定格式的 displayName:
<ClaimsTransformation Id="CreateDisplayNameFromFirstNameAndLastName" TransformationMethod="FormatStringMultipleClaims">
<InputClaims>
<InputClaim ClaimTypeReferenceId="givenName" TransformationClaimType="inputClaim1" />
<InputClaim ClaimTypeReferenceId="surName" TransformationClaimType="inputClaim2" />
</InputClaims>
<InputParameters>
<InputParameter Id="stringFormat" DataType="string" Value="{0} {1}" />
</InputParameters>
<OutputClaims>
<OutputClaim ClaimTypeReferenceId="displayName" TransformationClaimType="outputClaim" />
</OutputClaims>
</ClaimsTransformation>
- 输入声明:
- inputClaim1:Joe
- inputClaim2:Fernando
- 输入参数:
- stringFormat: {0}{1}
- 输出声明:
- outputClaim:Joe Fernando
GetLocalizedStringsTransformation
将本地化的字符串复制到声明中。 查看此声明转换的实时演示。
元素 | TransformationClaimType | 数据类型 | 说明 |
---|---|---|---|
OutputClaim | 本地化的字符串的名称 | string | 调用此声明转换后生成的声明类型列表。 |
使用 GetLocalizedStringsTransformation 声明转换:
LocalizedString
元素的ElementType
必须设为GetLocalizedStringsTransformationClaimType
。StringId
是定义的唯一标识符,稍后会用于声明转换。在声明转换中,指定要使用本地化字符串设置的声明列表。
ClaimTypeReferenceId
是对该策略的 ClaimsSchema 部分中已定义的声明的引用。TransformationClaimType
是在LocalizedString
元素的StringId
中定义的已本地化字符串的名称。将技术配置文件与内容定义(例如
api.selfasserted
)相关联。 以下示例将演示如何将技术配置文件与api.selfasserted
内容定义相关联。<Metadata> <Item Key="ContentDefinitionReferenceId">api.selfasserted</Item> </Metadata>
下图显示了如何借助本地化元素配置声明转换:
GetLocalizedStringsTransformation 示例
以下示例在本地化的字符串中查找电子邮件主题、正文、代码消息和电子邮件签名。 这些声明稍后由自定义电子邮件验证模板使用。
定义英语(默认)和西班牙语的已本地化字符串。
<Localization Enabled="true">
<SupportedLanguages DefaultLanguage="en" MergeBehavior="Append">
<SupportedLanguage>en</SupportedLanguage>
<SupportedLanguage>es</SupportedLanguage>
</SupportedLanguages>
<LocalizedResources Id="api.localaccountsignup.en">
<LocalizedStrings>
<LocalizedString ElementType="GetLocalizedStringsTransformationClaimType" StringId="email_subject">Contoso account email verification code</LocalizedString>
<LocalizedString ElementType="GetLocalizedStringsTransformationClaimType" StringId="email_message">Thanks for verifying your account!</LocalizedString>
<LocalizedString ElementType="GetLocalizedStringsTransformationClaimType" StringId="email_code">Your code is</LocalizedString>
<LocalizedString ElementType="GetLocalizedStringsTransformationClaimType" StringId="email_signature">Sincerely</LocalizedString>
</LocalizedStrings>
</LocalizedResources>
<LocalizedResources Id="api.localaccountsignup.es">
<LocalizedStrings>
<LocalizedString ElementType="GetLocalizedStringsTransformationClaimType" StringId="email_subject">Código de verificación del correo electrónico de la cuenta de Contoso</LocalizedString>
<LocalizedString ElementType="GetLocalizedStringsTransformationClaimType" StringId="email_message">Gracias por comprobar la cuenta de </LocalizedString>
<LocalizedString ElementType="GetLocalizedStringsTransformationClaimType" StringId="email_code">Su código es</LocalizedString>
<LocalizedString ElementType="GetLocalizedStringsTransformationClaimType" StringId="email_signature">Atentamente</LocalizedString>
</LocalizedStrings>
</LocalizedResources>
</Localization>
声明转换将声明类型 subject 的值设置为 StringId
email_subject 的值。
<ClaimsTransformation Id="GetLocalizedStringsForEmail" TransformationMethod="GetLocalizedStringsTransformation">
<OutputClaims>
<OutputClaim ClaimTypeReferenceId="subject" TransformationClaimType="email_subject" />
<OutputClaim ClaimTypeReferenceId="message" TransformationClaimType="email_message" />
<OutputClaim ClaimTypeReferenceId="codeIntro" TransformationClaimType="email_code" />
<OutputClaim ClaimTypeReferenceId="signature" TransformationClaimType="email_signature" />
</OutputClaims>
</ClaimsTransformation>
- 输出声明:
- subject:Contoso 帐户电子邮件验证码
- message:感谢验证你的帐户!
- codeIntro:你的代码是
- signature:此致
GetMappedValueFromLocalizedCollection
从输入声明的 Restriction 集合中映射元素。 查看此声明转换的实时演示。
元素 | TransformationClaimType | 数据类型 | 说明 |
---|---|---|---|
InputClaim | mapFromClaim | string | 该声明包含要在带 Restriction 集合的 restrictionValueClaim 声明中查找的文本。 |
OutputClaim | restrictionValueClaim | 字符串 | 包含 Restriction 集合的声明。 在调用声明转换后,此声明的值将包含选定项的值。 |
GetMappedValueFromLocalizedCollection 示例
下面的示例基于错误密钥查找错误消息描述。 ResponseMsg 声明包含一系列要显示给最终用户或发送给信赖方的错误消息。
<ClaimType Id="responseMsg">
<DisplayName>Error message: </DisplayName>
<DataType>string</DataType>
<UserInputType>Paragraph</UserInputType>
<Restriction>
<Enumeration Text="B2C_V1_90001" Value="You cannot sign in because you are a minor" />
<Enumeration Text="B2C_V1_90002" Value="This action can only be performed by gold members" />
<Enumeration Text="B2C_V1_90003" Value="You have not been enabled for this operation" />
</Restriction>
</ClaimType>
声明转换将查找项文本,并返回其值。 如果使用 <LocalizedCollection>
本地化限制,则声明转换返回本地化的值。
<ClaimsTransformation Id="GetResponseMsgMappedToResponseCode" TransformationMethod="GetMappedValueFromLocalizedCollection">
<InputClaims>
<InputClaim ClaimTypeReferenceId="responseCode" TransformationClaimType="mapFromClaim" />
</InputClaims>
<OutputClaims>
<OutputClaim ClaimTypeReferenceId="responseMsg" TransformationClaimType="restrictionValueClaim" />
</OutputClaims>
</ClaimsTransformation>
- 输入声明:
- mapFromClaim:B2C_V1_90001
- 输出声明:
- restrictionValueClaim:由于未成年,你无法登录。
LookupValue
基于另一个声明的值从值列表中查找声明值。 查看此声明转换的实时演示。
元素 | TransformationClaimType | 数据类型 | 说明 |
---|---|---|---|
InputClaim | inputParameterId | string | 包含查找值的声明 |
InputParameter | string | inputParameters 集合。 | |
InputParameter | errorOnFailedLookup | boolean | 控制在没有任何匹配查找时是否返回错误。 |
OutputClaim | outputClaim | 字符串 | 调用此声明转换后将生成的声明。 匹配 Id 的值。 |
LookupValue 示例
下面的示例在某一个 inputParameters 集合中查找域名。 声明转换查找标识符中的域名,并返回其值(应用程序 ID)。
<ClaimsTransformation Id="DomainToClientId" TransformationMethod="LookupValue">
<InputClaims>
<InputClaim ClaimTypeReferenceId="domainName" TransformationClaimType="inputParameterId" />
</InputClaims>
<InputParameters>
<InputParameter Id="contoso.com" DataType="string" Value="13c15f79-8fb1-4e29-a6c9-be0d36ff19f1" />
<InputParameter Id="microsoft.com" DataType="string" Value="0213308f-17cb-4398-b97e-01da7bd4804e" />
<InputParameter Id="test.com" DataType="string" Value="c7026f88-4299-4cdb-965d-3f166464b8a9" />
<InputParameter Id="errorOnFailedLookup" DataType="boolean" Value="false" />
</InputParameters>
<OutputClaims>
<OutputClaim ClaimTypeReferenceId="domainAppId" TransformationClaimType="outputClaim" />
</OutputClaims>
</ClaimsTransformation>
- 输入声明:
- inputParameterId: test.com
- 输入参数:
- contoso.com:13c15f79-8fb1-4e29-a6c9-be0d36ff19f1
- microsoft.com:0213308f-17cb-4398-b97e-01da7bd4804e
- test.com: c7026f88-4299-4cdb-965d-3f166464b8a9
- errorOnFailedLookup: false
- 输出声明:
- outputClaim:c7026f88-4299-4cdb-965d-3f166464b8a9
LookupValue 出现错误的示例
将 errorOnFailedLookup
输入参数设置为 true
时,LookupValue 声明转换始终从验证技术配置文件执行,该文件由自断言技术配置文件或 DisplayConrtol 调用。 自断言技术配置文件的 LookupNotFound
元数据控制向用户显示的错误消息。
下面的示例在某一个 inputParameters 集合中查找域名。 声明转换查找标识符中的域名,并返回其值(应用程序 ID)或引发错误消息。
<ClaimsTransformation Id="DomainToClientId" TransformationMethod="LookupValue">
<InputClaims>
<InputClaim ClaimTypeReferenceId="domainName" TransformationClaimType="inputParameterId" />
</InputClaims>
<InputParameters>
<InputParameter Id="contoso.com" DataType="string" Value="13c15f79-8fb1-4e29-a6c9-be0d36ff19f1" />
<InputParameter Id="microsoft.com" DataType="string" Value="0213308f-17cb-4398-b97e-01da7bd4804e" />
<InputParameter Id="test.com" DataType="string" Value="c7026f88-4299-4cdb-965d-3f166464b8a9" />
<InputParameter Id="errorOnFailedLookup" DataType="boolean" Value="true" />
</InputParameters>
<OutputClaims>
<OutputClaim ClaimTypeReferenceId="domainAppId" TransformationClaimType="outputClaim" />
</OutputClaims>
</ClaimsTransformation>
- 输入声明:
- inputParameterId: live.com
- 输入参数:
- contoso.com:13c15f79-8fb1-4e29-a6c9-be0d36ff19f1
- microsoft.com:0213308f-17cb-4398-b97e-01da7bd4804e
- test.com: c7026f88-4299-4cdb-965d-3f166464b8a9
- errorOnFailedLookup: true
- 错误:
- 在输入参数 ID 列表中找不到输入声明值的匹配项,errorOnFailedLookup 为 true。
NullClaim
清除给定声明的值。 查看此声明转换的实时演示。
元素 | TransformationClaimType | 数据类型 | 说明 |
---|---|---|---|
OutputClaim | claim_to_null | string | 声明的值设置为 NULL。 |
NullClaim 示例
使用此声明转换可从声明属性包中删除不必要的数据,因此会话 Cookie 会更小。 以下示例将删除 TermsOfService
声明类型的值。
<ClaimsTransformation Id="SetTOSToNull" TransformationMethod="NullClaim">
<OutputClaims>
<OutputClaim ClaimTypeReferenceId="TermsOfService" TransformationClaimType="claim_to_null" />
</OutputClaims>
</ClaimsTransformation>
- 输入声明:
- outputClaim:欢迎使用 Contoso 应用。 如果继续浏览和使用本网站,表示你同意遵守并受下列条款和条件的约束...
- 输出声明:
- outputClaim:Null
ParseDomain
获取电子邮件地址的域部分。 查看此声明转换的实时演示。
元素 | TransformationClaimType | 数据类型 | 说明 |
---|---|---|---|
InputClaim | emailAddress | 字符串 | 包含电子邮件地址的声明。 |
OutputClaim | 域 | 字符串 | 调用此声明转换后生成的声明 - 域。 |
ParseDomain 示例
使用此声明转换分析用户 @ 符号之后的域名。 以下声明转换演示如何分析 email 声明中的域名。
<ClaimsTransformation Id="SetDomainName" TransformationMethod="ParseDomain">
<InputClaims>
<InputClaim ClaimTypeReferenceId="email" TransformationClaimType="emailAddress" />
</InputClaims>
<OutputClaims>
<OutputClaim ClaimTypeReferenceId="domainName" TransformationClaimType="domain" />
</OutputClaims>
</ClaimsTransformation>
- 输入声明:
- emailAddress: joe@outlook.com
- 输出声明:
- domain: outlook.com
SetClaimIfBooleansMatch
检查布尔型声明是 true
还是 false
。 如果为 true,则使用 outputClaimIfMatched
输入参数中显示的值设置输出声明。 查看此声明转换的实时演示。
元素 | TransformationClaimType | 数据类型 | 说明 |
---|---|---|---|
InputClaim | claimToMatch | string | 要检查的声明类型。 Null 值会引发异常。 |
InputParameter | matchTo | string | 要与 claimToMatch 输入声明进行比较的值。 可能的值:true 或 false 。 |
InputParameter | outputClaimIfMatched | string | 要在输入声明等于 matchTo 输入参数时设置的值。 |
OutputClaim | outputClaim | 字符串 | 如果 claimToMatch 输入声明等于 matchTo 输入参数,则此输出声明包含 outputClaimIfMatched 输入参数的值。 |
SetClaimIfBooleansMatch 示例
例如,以下声明转换会检查 hasPromotionCode 声明的值是否等于 true
。 如果是,则将值返回到“未找到促销代码”。
<ClaimsTransformation Id="GeneratePromotionCodeError" TransformationMethod="SetClaimIfBooleansMatch">
<InputClaims>
<InputClaim ClaimTypeReferenceId="hasPromotionCode" TransformationClaimType="claimToMatch" />
</InputClaims>
<InputParameters>
<InputParameter Id="matchTo" DataType="string" Value="true" />
<InputParameter Id="outputClaimIfMatched" DataType="string" Value="Promotion code not found." />
</InputParameters>
<OutputClaims>
<OutputClaim ClaimTypeReferenceId="promotionCode" TransformationClaimType="outputClaim" />
</OutputClaims>
</ClaimsTransformation>
- 输入声明:
- claimToMatch:true
- 输入参数:
- matchTo:true
- outputClaimIfMatched:“未找到促销代码。”
- 输出声明:
- outputClaim:“未找到促销代码。”
SetClaimsIfRegexMatch
检查字符串声明 claimToMatch
和 matchTo
输入参数是否相等,并使用 outputClaimIfMatched
输入参数中提供的值设置输出声明,以及比较结果输出声明(此声明将基于比较结果设置为 true
或 false
)。
查看此声明转换的实时演示。
元素 | TransformationClaimType | 数据类型 | 说明 |
---|---|---|---|
inputClaim | claimToMatch | 字符串 | 要比较的声明类型。 |
InputParameter | matchTo | 字符串 | 要匹配的正则表达式。 |
InputParameter | outputClaimIfMatched | 字符串 | 字符串相等情况下要设置的值。 |
InputParameter | extractGroups | boolean | [可选] 指定正则表达式匹配是否应提取组值。 可能的值:true 或 false (默认值)。 |
OutputClaim | outputClaim | 字符串 | 如果正则表达式是匹配项,此输出声明包含 outputClaimIfMatched 输入参数的值。 如果没有匹配项,则为 null。 |
OutputClaim | regexCompareResultClaim | boolean | 正则表达式匹配结果输出声明类型,将基于匹配结果设置为 true 或 false 。 |
OutputClaim | 声明名称 | 字符串 | 如果 extractGroups 输入参数设置为 true,调用此声明转换后生成的声明类型列表。 声明的名称必须与正则表达式组名称匹配。 |
SetClaimsIfRegexMatch 示例
根据电话号码正则表达式模式检查提供的电话号码是否有效。
<ClaimsTransformation Id="SetIsPhoneRegex" TransformationMethod="SetClaimsIfRegexMatch">
<InputClaims>
<InputClaim ClaimTypeReferenceId="phone" TransformationClaimType="claimToMatch" />
</InputClaims>
<InputParameters>
<InputParameter Id="matchTo" DataType="string" Value="^[0-9]{4,16}$" />
<InputParameter Id="outputClaimIfMatched" DataType="string" Value="iPhone" />
</InputParameters>
<OutputClaims>
<OutputClaim ClaimTypeReferenceId="validationResult" TransformationClaimType="outputClaim" />
<OutputClaim ClaimTypeReferenceId="isPhoneBoolean" TransformationClaimType="regexCompareResultClaim" />
</OutputClaims>
</ClaimsTransformation>
- 输入声明:
- claimToMatch:"64854114520"
- 输入参数:
- matchTo: "^[0-9]{4,16}$"
- outputClaimIfMatched:“Phone”
- 输出声明:
- outputClaim:“iPhone”
- regexCompareResultClaim:true
包含提取组的 SetClaimsIfRegexMatch 的示例
检查提供的电子邮件地址是否有效,并返回电子邮件别名。 通过提取组查看此声明转换的实时演示。
<ClaimsTransformation Id="GetAliasFromEmail" TransformationMethod="SetClaimsIfRegexMatch">
<InputClaims>
<InputClaim ClaimTypeReferenceId="email" TransformationClaimType="claimToMatch" />
</InputClaims>
<InputParameters>
<InputParameter Id="matchTo" DataType="string" Value="(?<mailAlias>.*)@(.*)$" />
<InputParameter Id="outputClaimIfMatched" DataType="string" Value="isEmail" />
<InputParameter Id="extractGroups" DataType="boolean" Value="true" />
</InputParameters>
<OutputClaims>
<OutputClaim ClaimTypeReferenceId="validationResult" TransformationClaimType="outputClaim" />
<OutputClaim ClaimTypeReferenceId="isEmailString" TransformationClaimType="regexCompareResultClaim" />
<OutputClaim ClaimTypeReferenceId="mailAlias" />
</OutputClaims>
</ClaimsTransformation>
- 输入声明:
- claimToMatch: "emily@contoso.com"
- 输入参数:
- matchTo:
(?<mailAlias>.*)@(.*)$
- outputClaimIfMatched:“isEmail”
- extractGroups: true
- matchTo:
- 输出声明:
- outputClaim: "isEmail"
- regexCompareResultClaim:true
- mailAlias: emily
SetClaimsIfStringsAreEqual
检查字符串声明和 matchTo
输入参数是否相等,并使用 stringMatchMsg
和 stringMatchMsgCode
输入参数中提供的值设置输出声明,以及比较结果输出声明,将基于比较结果将此声明设置为 true
或 false
。
查看此声明转换的实时演示。
元素 | TransformationClaimType | 数据类型 | 说明 |
---|---|---|---|
InputClaim | inputClaim | string | 要比较的声明类型。 |
InputParameter | matchTo | string | 要与 inputClaim 进行比较的字符串。 |
InputParameter | stringComparison | 字符串 | 可能的值:Ordinal 或 OrdinalIgnoreCase 。 |
InputParameter | stringMatchMsg | string | 字符串相等情况下第一个要设置的值。 |
InputParameter | stringMatchMsgCode | 字符串 | 字符串相等情况下第二个要设置的值。 |
OutputClaim | outputClaim1 | 字符串 | 如果字符串相等,则此输出声明包含 stringMatchMsg 输入参数的值。 |
OutputClaim | outputClaim2 | 字符串 | 如果字符串相等,则此输出声明包含 stringMatchMsgCode 输入参数的值。 |
OutputClaim | stringCompareResultClaim | boolean | 比较结果输出声明类型,将基于比较结果设置为 true 或 false 。 |
SetClaimsIfStringsAreEqual 示例
可以使用此声明转换检查一个声明是否等于指定的值。 例如,以下声明转换将检查 termsOfUseConsentVersion 声明的值是否等于 v1
。 如果是,则将值更改为 v2
。
<ClaimsTransformation Id="CheckTheTOS" TransformationMethod="SetClaimsIfStringsAreEqual">
<InputClaims>
<InputClaim ClaimTypeReferenceId="termsOfUseConsentVersion" TransformationClaimType="inputClaim" />
</InputClaims>
<InputParameters>
<InputParameter Id="matchTo" DataType="string" Value="v1" />
<InputParameter Id="stringComparison" DataType="string" Value="ordinalIgnoreCase" />
<InputParameter Id="stringMatchMsgCode" DataType="string" Value="B2C_V1_90005" />
<InputParameter Id="stringMatchMsg" DataType="string" Value="The TOS is upgraded to v2" />
</InputParameters>
<OutputClaims>
<OutputClaim ClaimTypeReferenceId="termsOfUseConsentVersion" TransformationClaimType="outputClaim1" />
<OutputClaim ClaimTypeReferenceId="termsOfUseConsentVersionUpgradeCode" TransformationClaimType="outputClaim2" />
<OutputClaim ClaimTypeReferenceId="termsOfUseConsentVersionUpgradeResult" TransformationClaimType="stringCompareResultClaim" />
</OutputClaims>
</ClaimsTransformation>
- 输入声明:
- inputClaim: v1
- 输入参数:
- matchTo:V1
- stringComparison: ordinalIgnoreCase
- stringMatchMsgCode:B2C_V1_90005
- stringMatchMsg:TOS 升级到 v2
- 输出声明:
- outputClaim1:B2C_V1_90005
- outputClaim2:TOS 升级到 v2
- stringCompareResultClaim: true
SetClaimsIfStringsMatch
检查字符串声明和 matchTo
输入参数是否相等,并使用 outputClaimIfMatched
输入参数中提供的值设置输出声明,以及比较结果输出声明(此声明将基于比较结果设置为 true
或 false
)。
查看此声明转换的实时演示。
元素 | TransformationClaimType | 数据类型 | 说明 |
---|---|---|---|
InputClaim | claimToMatch | 字符串 | 要比较的声明类型。 |
InputParameter | matchTo | 字符串 | 要与 inputClaim 进行比较的字符串。 |
InputParameter | stringComparison | 字符串 | 可能的值:Ordinal 或 OrdinalIgnoreCase 。 |
InputParameter | outputClaimIfMatched | 字符串 | 字符串相等情况下要设置的值。 |
OutputClaim | outputClaim | 字符串 | 如果字符串相等,则此输出声明包含 outputClaimIfMatched 输入参数的值。 或者如果字符串不匹配,则为 NULL。 |
OutputClaim | stringCompareResultClaim | boolean | 比较结果输出声明类型,将基于比较结果设置为 true 或 false 。 |
SetClaimsIfStringsMatch 示例
例如,以下声明转换检查 ageGroup 声明的值是否等于 Minor
。 如果是,则返回 B2C_V1_90001
值。
<ClaimsTransformation Id="SetIsMinor" TransformationMethod="SetClaimsIfStringsMatch">
<InputClaims>
<InputClaim ClaimTypeReferenceId="ageGroup" TransformationClaimType="claimToMatch" />
</InputClaims>
<InputParameters>
<InputParameter Id="matchTo" DataType="string" Value="Minor" />
<InputParameter Id="stringComparison" DataType="string" Value="ordinalIgnoreCase" />
<InputParameter Id="outputClaimIfMatched" DataType="string" Value="B2C_V1_90001" />
</InputParameters>
<OutputClaims>
<OutputClaim ClaimTypeReferenceId="isMinor" TransformationClaimType="outputClaim" />
<OutputClaim ClaimTypeReferenceId="isMinorResponseCode" TransformationClaimType="stringCompareResultClaim" />
</OutputClaims>
</ClaimsTransformation>
- 输入声明:
- claimToMatch:Minor
- 输入参数:
- matchTo:Minor
- stringComparison: ordinalIgnoreCase
- outputClaimIfMatched:B2C_V1_90001
- 输出声明:
- isMinorResponseCode:true
- isMinor:B2C_V1_90001
StringContains
确定指定的子字符串是否出现在输入声明中。 结果是新布尔型声明,值为 true
或 false
。 如果参数值出现在此字符串中,则为 true
;否则为 false
。
查看此声明转换的实时演示。
元素 | TransformationClaimType | 数据类型 | 说明 |
---|---|---|---|
InputClaim | inputClaim | 字符串 | 要搜索的声明类型。 |
InputParameter | contains | 字符串 | 要搜索的值。 |
InputParameter | ignoreCase | string | 指定此项比较是否应忽略所比较字符串的大小写。 |
OutputClaim | outputClaim | 字符串 | 调用此声明转换后生成的声明。 一个布尔值,指示输入声明中是否出现了该子字符串。 |
StringContains 示例
使用此声明转换可以检查字符串声明类型是否包含某个子字符串。 以下示例检查 roles
字符串声明类型是否包含 admin 值。
<ClaimsTransformation Id="CheckIsAdmin" TransformationMethod="StringContains">
<InputClaims>
<InputClaim ClaimTypeReferenceId="roles" TransformationClaimType="inputClaim"/>
</InputClaims>
<InputParameters>
<InputParameter Id="contains" DataType="string" Value="admin"/>
<InputParameter Id="ignoreCase" DataType="string" Value="true"/>
</InputParameters>
<OutputClaims>
<OutputClaim ClaimTypeReferenceId="isAdmin" TransformationClaimType="outputClaim"/>
</OutputClaims>
</ClaimsTransformation>
- 输入声明:
- inputClaim:"Admin, Approver, Editor"
- 输入参数:
- contains: "admin,"
- ignoreCase: true
- 输出声明:
- outputClaim: true
StringSubstring
提取字符串声明类型的组成部分(从位于指定位置处的字符开始),并返回指定数目的字符。 查看此声明转换的实时演示。
元素 | TransformationClaimType | 数据类型 | 说明 |
---|---|---|---|
InputClaim | inputClaim | 字符串 | 包含该字符串的声明类型。 |
InputParameter | startIndex | int | 此实例中子字符串的起始字符位置(从零开始)。 |
InputParameter | length | int | 子字符串中的字符数。 |
OutputClaim | outputClaim | 字符串 | 与此实例中在 startIndex 处开头、具有指定长度的子字符串等效的一个字符串;如果 startIndex 等于此实例的长度且长度为零,则为空。 |
StringSubstring 示例
例如,获取国家/地区电话号码前缀。
<ClaimsTransformation Id="GetPhonePrefix" TransformationMethod="StringSubstring">
<InputClaims>
<InputClaim ClaimTypeReferenceId="phoneNumber" TransformationClaimType="inputClaim" />
</InputClaims>
<InputParameters>
<InputParameter Id="startIndex" DataType="int" Value="0" />
<InputParameter Id="length" DataType="int" Value="2" />
</InputParameters>
<OutputClaims>
<OutputClaim ClaimTypeReferenceId="phonePrefix" TransformationClaimType="outputClaim" />
</OutputClaims>
</ClaimsTransformation>
- 输入声明:
- inputClaim: "+1644114520"
- 输入参数:
- startIndex:0
- length:2
- 输出声明:
- outputClaim: "+1"
StringReplace
在声明类型字符串中搜索指定的值,并返回一个新的声明类型字符串,在该字符串中,当前字符串中出现的所有指定字符串已替换为另一个指定的字符串。
查看此声明转换的实时演示。
元素 | TransformationClaimType | 数据类型 | 说明 |
---|---|---|---|
InputClaim | inputClaim | 字符串 | 包含该字符串的声明类型。 |
InputParameter | oldValue | 字符串 | 要搜索的字符串。 |
InputParameter | newValue | string | 用于替换出现的所有 oldValue 的字符串 |
OutputClaim | outputClaim | boolean | 等效于当前字符串的字符串,只不过 oldValue 的所有实例已替换为 newValue。 如果在当前实例中找不到 oldValue,该方法将按原样返回当前实例。 |
StringReplace 示例
例如,通过删除 -
字符来规范化某个电话号码
<ClaimsTransformation Id="NormalizePhoneNumber" TransformationMethod="StringReplace">
<InputClaims>
<InputClaim ClaimTypeReferenceId="phoneNumber" TransformationClaimType="inputClaim" />
</InputClaims>
<InputParameters>
<InputParameter Id="oldValue" DataType="string" Value="-" />
<InputParameter Id="newValue" DataType="string" Value="" />
</InputParameters>
<OutputClaims>
<OutputClaim ClaimTypeReferenceId="phoneNumber" TransformationClaimType="outputClaim" />
</OutputClaims>
</ClaimsTransformation>
- 输入声明:
- inputClaim: "+164-411-452-054"
- 输入参数:
- oldValue: "-"
- newValue:""
- 输出声明:
- outputClaim: "+164411452054"
StringJoin
在每个元素或成员之间使用指定的分隔符,串联指定字符串集合声明类型的元素。
查看此声明转换的实时演示。
元素 | TransformationClaimType | 数据类型 | 说明 |
---|---|---|---|
InputClaim | inputClaim | stringCollection | 包含要串联的字符串的集合。 |
InputParameter | delimiter | 字符串 | 用作分隔符的字符串,例如逗号 , 。 |
OutputClaim | outputClaim | 字符串 | 由 inputClaim 字符串集合的成员组成的字符串,以 delimiter 输入参数分隔。 |
StringJoin 示例
以下示例提取用户角色的字符串集合,并将其转换为逗号分隔符字符串。 可以使用此方法在 Azure AD B2C 用户帐户中存储字符串集合。 以后在从目录读取帐户时,可以使用 StringSplit
将逗号分隔符字符串转换回字符串集合。
<ClaimsTransformation Id="ConvertRolesStringCollectionToCommaDelimiterString" TransformationMethod="StringJoin">
<InputClaims>
<InputClaim ClaimTypeReferenceId="roles" TransformationClaimType="inputClaim" />
</InputClaims>
<InputParameters>
<InputParameter DataType="string" Id="delimiter" Value="," />
</InputParameters>
<OutputClaims>
<OutputClaim ClaimTypeReferenceId="rolesCommaDelimiterConverted" TransformationClaimType="outputClaim" />
</OutputClaims>
</ClaimsTransformation>
- 输入声明:
- inputClaim:
[ "Admin", "Author", "Reader" ]
- inputClaim:
- 输入参数:
- delimiter: ","
- 输出声明:
- outputClaim:
"Admin,Author,Reader"
- outputClaim:
StringSplit
返回一个字符串数组,其中包含此实例中由指定字符串的元素分隔的子字符串。 查看此声明转换的实时演示。
元素 | TransformationClaimType | 数据类型 | 说明 |
---|---|---|---|
InputClaim | inputClaim | string | 包含要拆分的子字符串的字符串声明类型。 |
InputParameter | delimiter | 字符串 | 用作分隔符的字符串,例如逗号 , 。 |
OutputClaim | outputClaim | stringCollection | 一个字符串集合,其元素包含此字符串中由 delimiter 输入参数分隔的子字符串。 |
注意
将删除 OutputClaim
stringCollection 中的任何 现有元素。
StringSplit 示例
以下示例提取用户角色的逗号分隔符字符串,并将其转换为字符串集合。
<ClaimsTransformation Id="ConvertRolesToStringCollection" TransformationMethod="StringSplit">
<InputClaims>
<InputClaim ClaimTypeReferenceId="rolesCommaDelimiter" TransformationClaimType="inputClaim" />
</InputClaims>
<InputParameters>
<InputParameter DataType="string" Id="delimiter" Value="," />
</InputParameters>
<OutputClaims>
<OutputClaim ClaimTypeReferenceId="roles" TransformationClaimType="outputClaim" />
</OutputClaims>
</ClaimsTransformation>
- 输入声明:
- inputClaim:
Admin,Author,Reader
- inputClaim:
- 输入参数:
- delimiter: ","
- 输出声明:
- outputClaim:
[ "Admin", "Author", "Reader" ]
- outputClaim:
字符串声明转换表达式
Azure AD B2C 自定义策略中的声明转换表达式提供了有关租户 ID 和技术配置文件 ID 的上下文信息。
表达式 | 描述 | 示例 |
---|---|---|
{TechnicalProfileId} |
技术配置文件 ID 名称。 | Facebook-OAUTH |
{RelyingPartyTenantId} |
信赖方策略的租户 ID。 | your-tenant.onmicrosoft.com |
{TrustFrameworkTenantId} |
信任框架的租户 ID。 | your-tenant.onmicrosoft.com |
后续步骤
- 在 Azure AD B2C 社区 GitHub 存储库中查看更多声明转换示例