Configuración de la suscripción y el inicio de sesión con OpenID Connect genérico mediante Azure Active Directory B2C

Antes de comenzar, use el selector Elección de un tipo de directiva para elegir el tipo de directiva que va a configurar. Azure Active Directory B2C ofrece dos métodos para definir el modo en que los usuarios interactúan con las aplicaciones: por medio de flujos de usuario predefinidos o de directivas personalizadas totalmente configurables. Los pasos necesarios en este artículo son diferentes para cada método.

OpenID Connect es un protocolo de autenticación basado en OAuth 2.0 que se puede usar para el inicio de sesión de usuario seguro. La mayoría de los proveedores de identidades que usan este protocolo se admiten en Azure AD B2C.

En este artículo se explica cómo puede agregar proveedores de identidades personalizados de OpenID Connect en sus flujos de usuario.

Importante

Los puntos de conexión deben cumplir los requisitos de seguridad de Azure AD B2C. Las versiones anteriores de TLS y los cifrados están en desuso. Para obtener más información, consulte Requisitos de TLS y del conjunto de cifrado de Azure AD B2C.

Requisitos previos

Agregar el proveedor de identidades

  1. Inicie sesión en Azure Portal como administrador global del inquilino de Azure AD B2C.
  2. Si tiene acceso a varios inquilinos, seleccione el icono Configuración en el menú superior para cambiar al inquilino de Azure AD B2C desde el menú Directorios y suscripciones.
  3. Elija Todos los servicios en la esquina superior izquierda de Azure Portal, busque y seleccione Azure AD B2C.
  4. Seleccione Proveedores de identidades y luego Nuevo proveedor de OpenID Connect.
  5. Escriba un nombre. Por ejemplo, escriba Contoso.

Para definir el proveedor de identidades de OpenId Connect, agréguelo al elemento ClaimsProvider en el archivo de extensión de la directiva.

  1. Abra el archivo TrustFrameworkExtensions.xml.

  2. Busque el elemento ClaimsProviders. Si no existe, agréguelo debajo del elemento raíz.

  3. Agregue un nuevo elemento ClaimsProvider tal como se muestra a continuación:

    <ClaimsProvider>
      <Domain>contoso.com</Domain>
      <DisplayName>Login with Contoso</DisplayName>
      <TechnicalProfiles>
        <TechnicalProfile Id="Contoso-OpenIdConnect">
          <DisplayName>Contoso</DisplayName>
          <Description>Login with your Contoso account</Description>
          <Protocol Name="OpenIdConnect"/>
          <Metadata>
            <Item Key="METADATA">https://your-identity-provider.com/.well-known/openid-configuration</Item>
            <Item Key="client_id">00000000-0000-0000-0000-000000000000</Item>
            <Item Key="response_types">code</Item>
            <Item Key="scope">openid profile</Item>
            <Item Key="response_mode">form_post</Item>
            <Item Key="HttpBinding">POST</Item>
            <Item Key="UsePolicyInRedirectUri">false</Item>
          </Metadata>
          <!-- <CryptographicKeys>
            <Key Id="client_secret" StorageReferenceId="B2C_1A_ContosoSecret"/>
          </CryptographicKeys> -->
          <OutputClaims>
            <OutputClaim ClaimTypeReferenceId="issuerUserId" PartnerClaimType="oid"/>
            <OutputClaim ClaimTypeReferenceId="tenantId" PartnerClaimType="tid"/>
            <OutputClaim ClaimTypeReferenceId="givenName" PartnerClaimType="given_name" />
            <OutputClaim ClaimTypeReferenceId="surName" PartnerClaimType="family_name" />
            <OutputClaim ClaimTypeReferenceId="displayName" PartnerClaimType="name" />
            <OutputClaim ClaimTypeReferenceId="email" PartnerClaimType="email" />
            <OutputClaim ClaimTypeReferenceId="authenticationSource" DefaultValue="socialIdpAuthentication" AlwaysUseDefaultValue="true" />
            <OutputClaim ClaimTypeReferenceId="identityProvider" PartnerClaimType="iss" />
            <OutputClaim ClaimTypeReferenceId="objectId" PartnerClaimType="oid"/>
          </OutputClaims>
          <OutputClaimsTransformations>
            <OutputClaimsTransformation ReferenceId="CreateRandomUPNUserName"/>
            <OutputClaimsTransformation ReferenceId="CreateUserPrincipalName"/>
            <OutputClaimsTransformation ReferenceId="CreateAlternativeSecurityId"/>
            <OutputClaimsTransformation ReferenceId="CreateSubjectClaimFromAlternativeSecurityId"/>
          </OutputClaimsTransformations>
          <UseTechnicalProfileForSessionManagement ReferenceId="SM-SocialLogin"/>
        </TechnicalProfile>
      </TechnicalProfiles>
    </ClaimsProvider>
    

Configurar el proveedor de identidades

Cada proveedor de identidades de OpenID Connect describe un documento de metadatos que contiene la mayor parte de la información necesaria para iniciar sesión. Este documento de metadatos incluye las direcciones URL que se usan y la ubicación de las claves de firma pública del servicio. El documento de metadatos de OpenID Connect siempre se encuentra en un punto de conexión que termina en .well-known/openid-configuration. En cuanto al proveedor de identidades de OpenID Connect que quiere agregar, escriba su URL de metadatos.

En la URL de metadatos, escriba la dirección URL del documento de metadatos de OpenID Connect.

En los metadatos del perfil técnico <Item Key="METADATA">, escriba la dirección URL del documento de metadatos de OpenID Connect.

Id. de cliente y secreto

Para permitir que los usuarios inicien sesión, el proveedor de identidades pide a los desarrolladores que registren una aplicación en su servicio. Esta aplicación tiene un identificador que se denomina ID de cliente y un secreto de cliente.

El secreto del cliente es opcional. Sin embargo, debe proporcionar un secreto de cliente si el Tipo de respuesta es code, que usa el secreto para intercambiar el código para el token.

Para agregar el id. de cliente y el secreto de cliente, copie estos valores del proveedor de identidades y escríbalos en los campos correspondientes.

En los metadatos del perfil técnico <Item Key="client_id">, escriba el id. de cliente.

Creación de una clave de directiva

Si se requiere el secreto de cliente, almacene el secreto de cliente que haya registrado previamente en el inquilino de Azure AD B2C.

  1. Inicie sesión en Azure Portal.

  2. Asegúrese de que usa el directorio que contiene el inquilino de Azure AD B2C. Seleccione el filtro Directorio y suscripción en la barra de herramientas del portal.

  3. En la página Configuración del portal | Directorios y suscripciones, busque el directorio de Azure AD B2C en la lista Nombre de directorio y seleccione Cambiar.

  4. Elija Todos los servicios en la esquina superior izquierda de Azure Portal, y busque y seleccione Azure AD B2C.

  5. En la página de introducción, seleccione Identity Experience Framework.

  6. Seleccione Claves de directiva y luego Agregar.

  7. En Opciones, elija Manual.

  8. Escriba un nombre para la clave de directiva. Por ejemplo, ContosoSecret. Se agregará el prefijo B2C_1A_ automáticamente al nombre de la clave.

  9. En Secreto, escriba el secreto de cliente que haya registrado previamente.

  10. En Uso de claves, seleccione Signature.

  11. Haga clic en Crear.

  12. En el elemento XML CryptographicKeys, agregue el siguiente elemento:

    <CryptographicKeys>
      <Key Id="client_secret" StorageReferenceId="B2C_1A_ContosoSecret"/>
    </CryptographicKeys>
    

Ámbito

El ámbito define la información y los permisos que quiere recopilar del proveedor de identidades, por ejemplo openid profile. Para recibir el token de identificación del proveedor de identidades, se debe especificar el ámbito openid.

Sin ese token de identificador, los usuarios no pueden iniciar sesión en Azure AD B2C mediante el proveedor de identidades personalizado. Pueden anexarse otros ámbitos separados con espacios. Consulte la documentación del proveedor de identidades personalizado para ver otros ámbitos disponibles.

En Ámbito, escriba los ámbitos del proveedor de identidades. Por ejemplo, openid profile.

En los metadatos del perfil técnico <Item Key="scope">, escriba los ámbitos del proveedor de identidades. Por ejemplo, openid profile.

Tipo de respuesta

El tipo de respuesta describe qué tipo de información se envía en la llamada inicial al valor authorization_endpoint del proveedor de identidades personalizado. Pueden usarse estos tipos de respuesta:

  • code: según el flujo de código de autorización, se devolverá un código a Azure AD B2C. Azure AD B2C llama a token_endpoint para intercambiar el código del token.
  • id_token: se devuelve un token de identificador a Azure AD B2C desde el proveedor de identidades personalizado.

En Tipo de respuesta, seleccione code o id_token, en función de la configuración del proveedor de identidades.

En los metadatos del perfil técnico <Item Key="response_types">, seleccione code o id_token, según la configuración del proveedor de identidades.

Modo de respuesta

El modo de respuesta define el método que se debe usar para devolver los datos a Azure AD B2C desde el proveedor de identidades personalizado. Se pueden usar estos modos de respuesta:

  • form_post: este modo de respuesta se recomienda para mayor seguridad. La respuesta se transmite a través del método HTTP POST, con el código o token codificado en el cuerpo mediante el formato application/x-www-form-urlencoded.
  • query: el código o el token se devuelve como un parámetro de consulta.

En Modo de respuesta, seleccione form_post o query, en función de la configuración del proveedor de identidades.

En los metadatos del perfil técnico <Item Key="response_mode">, seleccione form_post o query, según la configuración del proveedor de identidades.

Sugerencia de dominio

La sugerencia de dominio se puede usar para ir directamente a la página de inicio de sesión del proveedor de identidades especificado, en lugar de hacer que el usuario lo seleccione en la lista de proveedores de identidades disponibles.

Para permitir este tipo de comportamiento, escriba un valor en la sugerencia de dominio. Para ir al proveedor de identidades personalizado, agregue el parámetro domain_hint=<domain hint value> al final de la solicitud cuando llame a Azure AD B2C para iniciar sesión.

En Sugerencia de dominio, escriba un nombre de dominio usado en la sugerencia de dominio.

En el elemento XML del perfil técnico <Domain>contoso.com</Domain>, escriba un nombre de dominio usado en la sugerencia de dominio. Por ejemplo, contoso.com.

Asignación de notificaciones

Una vez que el proveedor de identidades personalizado devuelve un token de id. a Azure AD B2C, Azure AD B2C debe poder asignar las notificaciones del token recibido a aquellas que Azure AD B2C ya reconoce y usa. Para cada una de las asignaciones que se detallan aquí, lea la documentación del proveedor de identidades personalizado para comprender las notificaciones que se devuelven en los tokens del proveedor de identidades:

  • Id. de usuario: especifique la notificación que proporciona el identificador único del usuario con sesión iniciada.
  • Nombre para mostrar: especifique la notificación que proporciona el nombre para mostrar o el nombre completo del usuario.
  • Nombre propio: especifique la notificación que proporciona el nombre del usuario.
  • Apellido: especifique la notificación que proporciona el apellido del usuario.
  • Correo electrónico: especifique la notificación que proporciona la dirección de correo electrónico del usuario.

El elemento OutputClaims contiene una lista de notificaciones devueltas por el proveedor de identidades. Asigne el nombre de la notificación definida en la directiva al nombre definido en el proveedor de identidades. En el elemento <OutputClaims>, configure el atributo PartnerClaimType con el nombre de notificación correspondiente tal como lo define el proveedor de identidades.

ClaimTypeReferenceId PartnerClaimType
issuerUserId especifique la notificación que proporciona el identificador único del usuario con sesión iniciada.
displayName especifique la notificación que proporciona el nombre para mostrar o el nombre completo del usuario.
givenName especifique la notificación que proporciona el nombre del usuario.
surName especifique la notificación que proporciona el apellido del usuario.
email especifique la notificación que proporciona la dirección de correo electrónico del usuario.
identityProvider Escriba la notificación que proporciona el nombre del emisor del token. Por ejemplo, iss. Si el proveedor de identidades no incluye la notificación del emisor en el token, establezca el atributo DefaultValue con un identificador único del proveedor de identidades. Por ejemplo, DefaultValue="contoso.com".

Adición del proveedor de identidades a un flujo de usuario

  1. En el inquilino de Azure AD B2C, seleccione Flujos de usuario.
  2. Haga clic en el flujo de usuario al que quiere agregar el proveedor de identidades.
  3. En Proveedores de identidades sociales, seleccione el proveedor de identidades que ha agregado. Por ejemplo, Contoso.
  4. Seleccione Guardar.

Prueba del flujo de usuario

  1. Para probar la directiva, seleccione Ejecutar flujo de usuario.
  2. En Aplicación, seleccione la aplicación web denominada testapp1 que registró anteriormente. La dirección URL de respuesta debe mostrar https://jwt.ms.
  3. Seleccione el botón Ejecutar flujo de usuario.
  4. En la página de registro o de inicio de sesión, seleccione el proveedor de identidades en el que desea iniciar sesión. Por ejemplo, Contoso.

Si el proceso de inicio de sesión se completa correctamente, el explorador se redirige a https://jwt.ms, que muestra el contenido del token devuelto por Azure AD B2C.

Adición de un recorrido del usuario

En este momento, el proveedor de identidades ya se ha configurado, pero no está disponible en ninguna de las pantallas de inicio de sesión. Si no tiene su propio recorrido del usuario personalizado, cree un duplicado de un recorrido del usuario de la plantilla existente; de lo contrario, continúe con el paso siguiente.

  1. Abra el archivo TrustFrameworkBase.xml del paquete de inicio.
  2. Busque y copie todo el contenido del elemento UserJourney que incluye Id="SignUpOrSignIn".
  3. Abra el archivo TrustFrameworkExtensions.xml y busque el elemento UserJourneys. Si el elemento no existe, agréguelo.
  4. Pegue todo el contenido del elemento UserJourney que ha copiado como elemento secundario del elemento UserJourneys.
  5. Cambie el identificador del recorrido del usuario. Por ejemplo, Id="CustomSignUpSignIn".

Adición del proveedor de identidades a un recorrido del usuario

Ahora que tiene un recorrido del usuario, agregue el nuevo proveedor de identidades al recorrido del usuario. En primer lugar, agregue un botón de inicio de sesión y, después, vincule el botón a una acción. La acción es el perfil técnico que creó anteriormente.

  1. Busque el elemento del paso de orquestación que incluye Type="CombinedSignInAndSignUp" o Type="ClaimsProviderSelection"en el recorrido del usuario. Normalmente es el primer paso de orquestación. El elemento ClaimsProviderSelections contiene una lista de proveedores de identidades con los que un usuario puede iniciar sesión. El orden de los elementos controla el orden de los botones de inicio de sesión que se presentan al usuario. Agregue un elemento XML ClaimsProviderSelection. Establezca el valor de TargetClaimsExchangeId en un nombre descriptivo.

  2. En el paso de orquestación siguiente, agregue un elemento ClaimsExchange. Establezca el Id en el valor del identificador de intercambio de notificaciones de destino. Actualice el valor de TechnicalProfileReferenceId al del identificador del perfil técnico que creó anteriormente.

En el siguiente código XML se muestran los dos primeros pasos de orquestación de un recorrido del usuario con el proveedor de identidades:

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

<OrchestrationStep Order="2" Type="ClaimsExchange">
  ...
  <ClaimsExchanges>
    <ClaimsExchange Id="ContosoExchange" TechnicalProfileReferenceId="Contoso-OpenIdConnect" />
  </ClaimsExchanges>
</OrchestrationStep>

Configuración de la directiva de usuario de confianza.

La directiva de usuario de confianza, por ejemplo SignUpSignIn.xml, especifica el recorrido del usuario que ejecutará Azure AD B2C. Busque el elemento DefaultUserJourney en el usuario de confianza. Actualice ReferenceId para que coincida con el identificador del recorrido del usuario, en el que agregó el proveedor de identidades.

En el ejemplo siguiente, para el recorrido de usuario CustomSignUpSignIn, el ReferenceId está establecido en CustomSignUpSignIn:

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

Carga de la directiva personalizada

  1. Inicie sesión en Azure Portal.
  2. Seleccione el icono Directorio y suscripción en la barra de herramientas del portal y, luego, elija el directorio que contiene el inquilino de Azure AD B2C.
  3. En Azure Portal, busque y seleccione Azure AD B2C.
  4. En Directivas, seleccione Identity Experience Framework.
  5. Seleccione Cargar directiva personalizada y, a continuación, cargue los dos archivos de directivas que ha cambiado, en el siguiente orden: la directiva de extensiones, por ejemplo TrustFrameworkExtensions.xml, luego la directiva de usuarios de confianza, como SignUpSignIn.xml.
  1. Seleccione la directiva de usuarios de confianza, por ejemplo B2C_1A_signup_signin.
  2. En Aplicación, seleccione la aplicación web que registró anteriormente. La dirección URL de respuesta debe mostrar https://jwt.ms.
  3. Seleccione el botón Ejecutar ahora.
  4. En la página de registro o de inicio de sesión, seleccione Contoso para iniciar sesión con la cuenta de Google.

Si el proceso de inicio de sesión se completa correctamente, el explorador se redirige a https://jwt.ms, que muestra el contenido del token devuelto por Azure AD B2C.

Problemas conocidos

  • Azure AD B2C no es compatible con JWE (JSON Web Encryption) para intercambiar tokens cifrados con proveedores de identidad OpenID Connect.

Pasos siguientes

Para más información, consulte la guía de referencia Perfil técnico de OpenId Connect.