RelyingParty
참고 항목
Azure Active Directory B2C에서 사용자 지정 정책은 주로 복잡한 시나리오를 해결하기 위해 설계되었습니다. 대부분의 시나리오에서 기본 제공 사용자 흐름을 사용하는 것이 좋습니다. 아직 수행하지 않았다면 Active Directory B2C에서 사용자 지정 정책 시작하기에서 사용자 지정 정책 스타터 팩에 대해 알아봅니다.
RelyingParty 요소는 Azure AD B2C(Azure Active Directory B2C)로의 현재 요청에 대해 적용할 사용자 경험을 지정합니다. 또한 발급된 토큰의 일부로 RP(신뢰 당사자) 애플리케이션에 필요한 클레임 목록도 지정합니다. 웹, 모바일, 데스크톱 애플리케이션 등의 RP 애플리케이션은 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.onmicrosoft.com"
PolicyId="B2C_1A_signup_signin"
PublicPolicyUri="http://your-tenant.onmicrosoft.com/B2C_1A_signup_signin">
<BasePolicy>
<TenantId>your-tenant.onmicrosoft.com</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 | RP 애플리케이션의 기본 사용자 경험입니다. |
엔드포인트 | 0:1 | 엔드포인트 목록입니다. 자세한 내용은 UserInfo 엔드포인트를 참조하세요. |
UserJourneyBehaviors | 0:1 | 사용자 경험 동작의 범위입니다. |
TechnicalProfile | 1:1 | RP 애플리케이션에서 지원하는 기술 프로필입니다. 기술 프로필은 RP 애플리케이션이 Azure AD B2C에 연락하는 계약을 제공합니다. |
이전 표에 표시된 순서대로 RelyingParty 자식 요소를 만들어야 합니다.
엔드포인트
Endpoints 요소에는 다음 요소가 포함됩니다.
요소 | 발생 | 설명 |
---|---|---|
엔드포인트 | 1:1 | 엔드포인트에 대한 참조입니다. |
엔드포인트 요소에는 다음 특성이 포함됩니다.
attribute | 필수 | 설명 |
---|---|---|
ID | 예 | 엔드포인트의 고유 식별자입니다. |
UserJourneyReferenceId | 예 | 정책의 사용자 경험 식별자입니다. 자세한 내용은 사용자 경험을 참조 하세요. |
다음 예제에서는 UserInfo 엔드포인트가 있는 신뢰 당사자를 보여줍니다.
<RelyingParty>
<DefaultUserJourney ReferenceId="SignUpOrSignIn" />
<Endpoints>
<Endpoint Id="UserInfo" UserJourneyReferenceId="UserInfoJourney" />
</Endpoints>
...
DefaultUserJourney
요소는 DefaultUserJourney
Base 또는 Extensions 정책에 정의된 사용자 경험의 식별자에 대한 참조를 지정합니다. 다음 예제에서는 RelyingParty 요소에 지정된 등록 또는 로그인 사용자 경험을 보여 줍니다 .
B2C_1A_signup_signin 정책:
<RelyingParty>
<DefaultUserJourney ReferenceId="SignUpOrSignIn">
...
B2C_1A_TrustFrameWorkBase 또는 B2C_1A_TrustFrameworkExtensionPolicy:
<UserJourneys>
<UserJourney Id="SignUpOrSignIn">
...
DefaultUserJourney 요소에는 다음과 같은 특성이 포함됩니다.
attribute | 필수 | 설명 |
---|---|---|
참조 | 예 | 정책의 사용자 경험 식별자입니다. 자세한 내용은 사용자 경험을 참조 하세요. |
UserJourneyBehaviors
UserJourneyBehaviors 요소에는 다음 요소가 포함됩니다.
요소 | 발생 | 설명 |
---|---|---|
SingleSignOn | 0:1 | 사용자 경험의 SSO(Single Sign-On) 세션 동작 범위입니다. |
SessionExpiryType | 0:1 | 세션의 인증 동작입니다. 가능한 값은 Rolling 또는 Absolute 입니다. 값(기본값)은 Rolling 사용자가 애플리케이션에서 지속적으로 활성화되는 한 사용자가 로그인 상태로 유지됨을 나타냅니다. Absolute 값은 애플리케이션 세션 수명에 따라 지정된 기간 후 사용자가 강제로 다시 인증을 해야 함을 나타냅니다. |
SessionExpiryInSeconds | 0:1 | 인증에 성공하면 사용자의 브라우저에 저장된 정수로 지정된 Azure AD B2C 세션 쿠키의 수명입니다. 기본값은 86,400초(24시간)입니다. 최소값은 900초(15분)입니다. 최대값은 86,400초(24시간)입니다. |
JourneyInsights | 0:1 | 사용할 Application Insights 계측 키입니다. |
ContentDefinitionParameters | 0:1 | 콘텐츠 정의 로드 URI에 추가할 키 값 쌍의 목록입니다. |
JourneyFraming | 0:1 | 이 정책의 사용자 인터페이스를 iframe에 로드할 수 있습니다. |
ScriptExecution | 0:1 | 지원되는 JavaScript 실행 모드입니다. 가능한 값은 Allow 또는 Disallow (기본값)입니다. |
위의 요소를 사용하는 경우 테이블에 지정된 순서대로 UserJourneyBehaviors 요소에 추가해야 합니다. 예를 들어 JourneyInsights 요소는 ScriptExecution 요소 앞(위)에 추가되어야 합니다.
SingleSignOn
SingleSignOn 요소에는 다음 특성이 포함됩니다.
attribute | 필수 | 설명 |
---|---|---|
범위 | 예 | Single Sign-On 동작의 범위입니다. 가능한 값: Suppressed , Tenant , Application 또는 Policy . 값은 Suppressed 동작이 표시되지 않으며 사용자에게 항상 ID 공급자 선택 메시지가 표시됨을 나타냅니다. 이 값은 Tenant 동작이 테넌트 내의 모든 정책에 적용됨을 나타냅니다. 예를 들어 테넌트에 대한 두 가지 정책 과정을 탐색하는 사용자에게 ID 공급자 선택을 묻는 메시지가 표시되지 않습니다. 이 값은 Application 요청을 만드는 애플리케이션에 대한 모든 정책에 동작이 적용됨을 나타냅니다. 예를 들어 애플리케이션의 두 공용 경험 간을 이동하는 사용자에게는 ID 공급자를 선택하라는 메시지가 표시되지 않습니다. 이 값은 Policy 동작이 정책에만 적용된다는 것을 나타냅니다. 예를 들어 트러스트 프레임워크에 대한 두 가지 정책 과정을 탐색하는 사용자에게 정책 간에 전환할 때 ID 공급자를 선택하라는 메시지가 표시됩니다. |
KeepAliveInDays | 아니요 | 사용자가 로그인 상태를 유지한 기간을 제어합니다. 값을 0으로 설정하면 KMSI 기능이 해제됩니다. 기본값은 (사용 안 함)입니다 0 . 최소 날짜입니다 1 . 최대 일 수입니다 90 . 자세한 내용은 로그인 유지를 참조하세요. |
EnforceIdTokenHintOnLogout | 아니요 | 클라이언트와 함께 최종 사용자의 현재 인증된 세션에 대한 힌트로 이전에 발급된 ID 토큰을 로그아웃 엔드포인트에 전달하도록 강제 적용합니다. 가능한 값은 false (기본값) 또는 true 입니다. 자세한 내용은 OpenID Connect를 사용하여 웹 로그인을 참조하세요. |
JourneyInsights
JourneyInsights 요소에는 다음 특성이 포함됩니다.
attribute | 필수 | 설명 |
---|---|---|
TelemetryEngine | 예 | 값은 ApplicationInsights 여야 합니다. |
InstrumentationKey | 예 | Application Insights 요소의 계측 키를 포함하는 문자열입니다. |
DeveloperMode | 예 | 가능한 값은 true 또는 false 입니다. 이 경우 true Application Insights는 처리 파이프라인을 통해 원격 분석을 신속하게 처리합니다. 이 설정은 개발에 좋지만 대용량으로 제한됩니다. 자세한 활동 로그는 사용자 지정 정책 개발에 도움이 되도록 설계되었습니다. 프로덕션에서 개발 모드를 사용하지 않습니다. 로그는 개발 중에 ID 공급자와 주고 받는 모든 클레임을 수집합니다. 프로덕션 환경에서 사용되는 경우 개발자는 자신이 소유한 App Insights 로그에 수집된 개인 데이터에 대한 책임을 맡습니다. 이러한 자세한 로그는 이 값이 로 설정된 true 경우에만 수집됩니다. |
ClientEnabled | 예 | 가능한 값은 true 또는 false 입니다. 값이 true 인 경우 페이지 보기 및 클라이언트 쪽 오류 추적용으로 Application Insights 클라이언트 쪽 스크립트를 전송합니다. |
ServerEnabled | 예 | 가능한 값은 true 또는 false 입니다. 이 경우 true 기존 UserJourneyRecorder JSON을 사용자 지정 이벤트로 Application Insights에 보냅니다. |
TelemetryVersion | 예 | 값은 1.0.0 여야 합니다. |
자세한 내용은 로그 수집을 참조 하세요.
ContentDefinitionParameters
Azure AD B2C에서 사용자 지정 정책을 사용하면 쿼리 문자열에 매개 변수를 보낼 수 있습니다. 매개 변수를 HTML 엔드포인트로 전달하면 페이지 콘텐츠를 동적으로 변경할 수 있습니다. 예를 들어 웹 또는 모바일 애플리케이션에서 전달한 매개 변수를 기반으로 Azure AD B2C 등록 또는 로그인 페이지에서 배경 이미지를 변경할 수 있습니다. Azure AD B2C는 쿼리 문자열 매개 변수를 aspx 파일과 같은 동적 HTML 파일에 전달합니다.
다음 예제에서는 쿼리 문자열의 hawaii
값으로 명명된 campaignId
매개 변수를 전달합니다.
https://login.microsoft.com/contoso.onmicrosoft.com/oauth2/v2.0/authorize?pB2C_1A_signup_signin&client_id=00001111-aaaa-2222-bbbb-3333cccc4444&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의 쿼리 문자열에 추가되는 키 값 쌍을 포함하는 문자열입니다. |
ContentDefinitionParameter 요소에는 다음 특성이 포함됩니다.
attribute | 필수 | 설명 |
---|---|---|
입력 | 예 | 키 값 쌍의 이름입니다. |
자세한 내용은 사용자 지정 정책을 사용하여 동적 콘텐츠로 UI 구성을 참조 하세요.
JourneyFraming
JourneyFraming 요소에는 다음 특성이 포함됩니다.
attribute | 필수 | 설명 |
---|---|---|
설정됨 | 예 | Iframe 내에서 이 정책을 로드할 수 있습니다. 가능한 값은 false (기본값) 또는 true 입니다. |
원본 | 예 | iframe을 호스트할 도메인을 포함합니다. 자세한 내용은 iframe에서 Azure B2C 로드를 참조하세요. |
TechnicalProfile
TechnicalProfile 요소에는 다음 특성이 포함됩니다.
attribute | 필수 | 설명 |
---|---|---|
ID | 예 | 값은 PolicyProfile 여야 합니다. |
TechnicalProfile에는 다음 요소가 포함됩니다.
요소 | 발생 | 설명 |
---|---|---|
DisplayName | 1:1 | 기술 프로필의 이름을 포함하는 문자열입니다. |
설명 | 0:1 | 기술 프로필에 대한 설명을 포함하는 문자열입니다. |
프로토콜 | 1:1 | 페더레이션에 사용되는 프로토콜입니다. |
메타데이터 | 0:1 | 신뢰 당사자와 다른 커뮤니티 참가자 간의 상호 작용을 구성하기 위해 트랜잭션 과정에서 엔드포인트와 통신하기 위해 프로토콜에서 사용하는 키/값 쌍의 항목 컬렉션입니다. |
InputClaims | 1:1 | 기술 프로필의 입력으로 가져오는 클레임 형식 목록입니다. 이러한 각 요소에는 ClaimsSchema 섹션 또는 이 정책 파일이 상속하는 정책에 이미 정의된 ClaimType에 대한 참조가 포함되어 있습니다. |
OutputClaims | 1:1 | 기술 프로필의 출력으로 가져오는 클레임 형식 목록입니다. 이러한 각 요소에는 ClaimsSchema 섹션 또는 이 정책 파일이 상속하는 정책에 이미 정의된 ClaimType에 대한 참조가 포함되어 있습니다. |
SubjectNamingInfo | 1:1 | 토큰에 사용되는 주체 이름입니다. |
Protocol 요소에는 다음 특성이 포함됩니다.
attribute | 필수 | 설명 |
---|---|---|
입력 | 예 | 기술 프로필의 일부로 사용되는 Azure AD B2C에서 지원하는 유효한 프로토콜의 이름입니다. 가능한 값은 OpenIdConnect 또는 SAML2 입니다. 이 값은 OpenIdConnect OpenID 기본 사양에 따라 OpenID Connect 1.0 프로토콜 표준을 나타냅니다. SAML2 는 OASIS 사양에 따른 SAML 2.0 프로토콜 표준을 나타냅니다. |
메타데이터
프로토콜인 경우 SAML
메타데이터 요소에는 다음 요소가 포함됩니다. 자세한 내용은 Azure AD B2C에서 SAML 애플리케이션을 등록하는 옵션을 참조하세요.
attribute | 필수 | 설명 |
---|---|---|
IdpInitiatedProfileEnabled | 아니요 | IDP 시작 흐름이 지원되는지 여부를 나타냅니다. 가능한 값은 true 또는 false (기본값)입니다. |
XmlSignatureAlgorithm | 아니요 | Azure AD B2C가 SAML 응답에 서명하는 데 사용하는 메서드입니다. 가능한 값: Sha256 , Sha384 , Sha512 또는 Sha1 . 양쪽의 서명 알고리즘을 같은 값으로 구성해야 합니다. 인증서가 지원하는 알고리즘만 사용하세요. SAML 어설션을 구성하려면 SAML 발급자 기술 프로필 메타데이터를 참조하세요. |
DataEncryptionMethod | 아니요 | AES(Advanced Encryption Standard) 알고리즘을 사용하여 Azure AD B2C가 데이터를 암호화하는 데 사용하는 방법을 나타냅니다. 메타데이터는 SAML 응답의 <EncryptedData> 요소 값을 제어합니다. 가능한 값은 Aes256 (기본값), Aes192 , Sha512 또는 Aes128 입니다. |
KeyEncryptionMethod | 아니요 | Azure AD B2C가 데이터를 암호화하는 데 사용된 키의 복사본을 암호화하는 데 사용하는 메서드를 나타냅니다. 메타데이터는 SAML 응답의 <EncryptedKey> 요소 값을 제어합니다. 가능한 값: Rsa15 (기본값) - RSA PKCS(공개 키 암호화 표준) 버전 1.5 알고리즘- RsaOaep RSA OAEP(최적 비대칭 암호화 패딩) 암호화 알고리즘. |
UseDetachedKeys | 아니요 | 가능한 값: true 또는 false (기본값) 값이 설정 true 되면 Azure AD B2C는 암호화된 어설션의 형식을 변경합니다. 분리된 키를 사용하면 EncryptedData가 아닌 EncrytedAssertion의 자식으로 암호화된 어설션이 추가됩니다. |
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로 채워집니다. 자세한 내용은 토큰, 세션 및 Single Sign-On 구성을 참조하세요. - SAML 토큰 -
<Subject><NameID>
주체 요소를 식별하는 요소입니다. NameId 형식을 수정할 수 있습니다.
SubjectNamingInfo 요소에는 다음 특성이 포함됩니다.
attribute | 필수 | 설명 |
---|---|---|
ClaimType | 예 | 출력 클레임의 PartnerClaimType에 대한 참조입니다. 신뢰 당사자 정책 OutputClaims 컬렉션에서 PartnerClaimType을 사용하여 출력 클레임을 정의해야 합니다. 예를 들면 <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": "aaaaaaaa-0000-1111-2222-bbbbbbbbbbbb",
...
}
다음 예제에서는 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>