Compartir a través de


Personalización del portal para desarrolladores de API Management en WordPress

SE APLICA A: Desarrollador | Básico | Estándar | Premium

En este artículo se muestra cómo configurar un complemento del portal para desarrolladores de código abierto (versión preliminar) para personalizar el portal para desarrolladores de API Management en WordPress. Con el complemento, convierta cualquier sitio de WordPress en un portal para desarrolladores. Aproveche las funcionalidades del sitio en WordPress para personalizar y agregar características al portal para desarrolladores, como localización, menús contraíbles y expandibles, hojas de estilos personalizadas, descargas de archivos, etc.

En este artículo, creará un sitio de WordPress en Azure App Service y configurará el complemento del portal para desarrolladores en el sitio de WordPress. Microsoft Entra ID está configurado para la autenticación en el sitio de WordPress y en el portal para desarrolladores.

Requisitos previos

  • Una instancia de API Management Si es necesario, crear una instancia.

    Nota:

    Actualmente, el complemento no se admite en los niveles de API Management v2.

  • Habilite y publique el portal para desarrolladores. Para conocer los pasos, vea Tutorial: Acceso y personalización del portal para desarrolladores.
  • Permisos para crear un registro de aplicaciones en un inquilino de Microsoft Entra asociado a la suscripción de Azure.
  • Archivos de instalación para el complemento WordPress del portal para desarrolladores y el tema personalizado de WordPress desde el repositorio de complementos. Descargue los siguientes archivos ZIP desde la carpeta dist del repositorio:
    • apim-devportal.zip - Archivo de complemento
    • twentytwentyfour.zip - Archivo de tema

Paso 1: Creación de WordPress en App Service

En este escenario, creará un sitio administrado de WordPress hospedado en Azure App Service. Éstos son unos breves pasos:

  1. En Azure Portal, vaya a https://portal.azure.com/#create/WordPress.WordPress.

  2. En la página Crear WordPress en App Service, en la pestaña Aspectos básicos, escriba los detalles del proyecto.

    Registre el nombre de usuario y la contraseña del administrador de WordPress en un lugar seguro. Estas credenciales son necesarias para iniciar sesión en el sitio de administración de WordPress e instalar el complemento en un paso posterior.

  3. En la pestaña Complementos:

    1. Seleccione los valores predeterminados recomendados para Correo electrónico con Azure Communication Services, Azure CDN, y Azure Blob Storage.
    2. En Red virtual, seleccione el valor de Nuevo o una red virtual existente.
  4. En la pestaña Implementación, deje sin seleccionar Agregar espacio de ensayo.

  5. Seleccione Revisar y crear para ejecutar la validación final.

  6. Seleccione Crear para completar la implementación de App Service.

El servicio de aplicaciones puede tardar varios minutos en implementarse.

Paso 2: Crear un nuevo registro de aplicaciones de Microsoft Entra

En este paso, cree una nueva aplicación de Microsoft Entra. En pasos posteriores, configurará esta aplicación como proveedor de identidades para la autenticación en el servicio de aplicaciones y en el portal para desarrolladores en la instancia de API Management.

  1. En Azure Portal, vaya a Registros de aplicaciones>+ Nuevo registro.

  2. Proporcione el nuevo nombre de la aplicación y, en tipos de cuenta admitidos, seleccione Cuentas en este directorio organizativo solo. Seleccione Registrar.

  3. En la página Información general, copie y almacene de forma segura el Identificador de aplicación (cliente) y Id. de directorio (inquilino). Necesitará estos valores en pasos posteriores para configurar la autenticación en la instancia de API Management y App Service Captura de pantalla de la página Información general del registro de aplicaciones en el portal.

  4. En el menú de la izquierda, en Administrar, seleccione Autenticación>+ Agregar una plataforma.

  5. En la página Configurar plataformas, seleccione Web.

  6. En la página Configurar web, escriba el siguiente URI de redirección, sustituya el nombre del servicio de aplicaciones y seleccione Configurar:

    https://app-service-name>.azurewebsites.net/.auth/login/aad/callback

  7. Seleccione + Agregar una plataforma de nuevo. Seleccione Aplicación de página única.

  8. En la página Configurar aplicación de página única, escriba el siguiente URI de redirección, sustituya el nombre de la instancia de API Management y seleccione Configurar:

    https://<apim-instance-name>.developer.azure-api.net/signin

  9. En la página Autenticación, en Aplicación de página única, seleccione Agregar URI y escriba el siguiente URI, sustituyendo el nombre de la instancia de API Management:

    https://<apim-instance-name>.developer.azure-api.net/

  10. En flujos híbridos y concesión implícita, seleccione tokens de identificador y seleccione Guardar.

  11. En el menú izquierdo, en Administrar, seleccione Configuración de token>+ Agregar notificación opcional.

  12. En la página Agregar notificación opcional, seleccione Id. y, a continuación, seleccione las siguientes notificaciones: correo electrónico, family_name, given_name, onprem_sid, preferred_username, upn. Seleccione Agregar.

  13. Cuando se le solicite, seleccione Activar el correo electrónico de Microsoft Graph, el permiso de perfil. Seleccione Agregar.

  14. En el menú de la izquierda, en Administrar seleccione Permisos de API y confirme que están presentes los siguientes permisos de Microsoft Graph: Correo electrónico, perfil, User.Read.

    Captura de pantalla de los permisos de API en el portal.

  15. En el menú izquierdo, en Administrar, seleccione Certificados y secretos>+ Nuevo secreto de cliente.

  16. Configure los valores del secreto y seleccione Agregar. Copie y almacene de forma segura el Valor del secreto inmediatamente después de que se genere. Necesita este valor en pasos posteriores para agregar la aplicación a la instancia de API Management y App Service para la autenticación.

  17. En el menú de la izquierda, en Administrar, seleccione Exponer una API. Anote el URI de identificador de aplicación predeterminado. Opcionalmente, agregue ámbitos personalizados si es necesario.

Paso 3: Habilitación de la autenticación en el servicio de aplicaciones

En este paso, agregue el registro de aplicaciones de Microsoft Entra como proveedor de identidades para la autenticación en el servicio de aplicaciones de WordPress.

  1. En el portal, vaya al servicio de aplicaciones de WordPress.
  2. En el menú izquierdo, en Configuración, seleccione Autenticación>Agregar proveedor de identidades.
  3. En la pestaña Aspectos básicos, en proveedor de identidades, seleccione Microsoft.
  4. En Registro de aplicaciones, seleccione Proporcione los detalles de un registro de aplicación existente.
    1. Escriba el Identificador de aplicación (cliente) y Secreto de cliente del registro de la aplicación que creó en el paso anterior.
    2. En URL del emisor, escriba cualquiera de los siguientes valores para el punto de conexión de autenticación: https://login.microsoftonline.com/<tenant-id> o https://sts.windows.net/<tenantid>. Reemplace <tenant-id> por el Id. de directorio (inquilino) del registro de la aplicación.

      Importante

      No use el punto de conexión de la versión 2.0 para la dirección URL del emisor (dirección URL que termina en /v2.0).

  5. En Audiencias de tokens permitidas, escriba el URI de identificador de aplicación del registro de la aplicación. Ejemplo: api://<app-id>.
  6. En Comprobaciones adicionales, seleccione los valores adecuados para su entorno o use los valores predeterminados.
  7. Acepte los valores predeterminados para la configuración restante y seleccione Agregar.

El proveedor de identidades se agrega al servicio de aplicaciones.

Paso 4: Habilitación de la autenticación en el portal para desarrolladores de API Management

Configure el mismo registro de aplicaciones de Microsoft Entra como proveedor de identidades para el portal para desarrolladores de API Management.

  1. En el portal, vaya a la instancia de API Management.

  2. En el menú izquierdo, en Portal para desarrolladores, seleccione Identidades>+ Agregar.

  3. En la página Agregar proveedor de identidades, seleccione Azure Active Directory (Id. de Microsoft Entra).

  4. Escriba el Id. de cliente, Secreto de cliente, y Inquilino de Signin del registro de la aplicación que creó en un paso anterior. El Inquilino de Signin es el Identificador de directorio (inquilino) del registro de la aplicación.

  5. En Biblioteca de cliente, seleccione MSAL.

  6. Acepte los valores predeterminados para la configuración restante y seleccione Agregar.

  7. Vuelva a publicar el portal para desarrolladores para aplicar los cambios.

  8. Pruebe la autenticación iniciando sesión en el portal para desarrolladores en la siguiente dirección URL, sustituyendo el nombre de la instancia de API Management: https://<apim-instance-name>.developer.azure-api.net/signin. Seleccione el botón Azure Active Directory (Microsoft Entra ID) en la parte inferior para iniciar sesión.

    Al abrirlo por primera vez, es posible que se le pida que dé su consentimiento a permisos específicos.

Paso 5: Configuración del portal para desarrolladores en API Management

Actualice la configuración del portal para desarrolladores en la instancia de API Management para habilitar CORS e incluir el sitio de App Service como origen del portal.

  1. Vaya a la instancia de API Management en Azure Portal.
  2. En el menú de la izquierda, en Portal para desarrolladores, seleccione Información general del portal.
  3. En la pestaña Información general del portal, seleccione Habilitar CORS.
  4. En el menú de la izquierda, en Portal para desarrolladores, seleccione Configuración del portal.
  5. En la pestaña configuración del portal autohospedado, escriba el nombre de host de su sitio de WordPress en App Service como origen del portal, sustituyendo el nombre del servicio de aplicaciones en la siguiente dirección URL: https://<yourapp-service-name>.azurewebsites.net
  6. Vuelva a publicar el portal para desarrolladores para aplicar los cambios.

Además, actualice la configuración de directiva de cors en la instancia de API Management para agregar el sitio de App Service como origen permitido. Este valor es necesario para permitir llamadas desde la consola de prueba del portal para desarrolladores en el sitio de WordPress.

Agregue el siguiente valor de origin en la configuración de la directivacors:

<cors ...>
    <allowed-origins>
        [...]
        <origin>https://<yourapp-service-name>.azurewebsites.net</origin>
    </allowed-origins>
</cors>

Obtenga más información sobre cómo establecer o editar directivas.

Paso 6: Navegar al sitio de administración de WordPress y cargar el tema personalizado

En este paso, cargará el tema personalizado para el portal para desarrolladores de API Management en el sitio de administración de WordPress.

Importante

Se recomienda cargar el tema proporcionado en el repositorio de complementos. El tema se basa en el tema Twenty Twenty Four y se personaliza para admitir la funcionalidad del portal para desarrolladores en WordPress. Si decide usar un tema diferente, es posible que algunas funciones no funcionen según lo previsto o requieran una personalización adicional.

  1. Abra el sitio web de administración de WordPress en la siguiente dirección URL, sustituyendo el nombre de su servicio de aplicaciones: http://<app-service-name>.azurewebsites.net/wp-admin

    Al abrirlo por primera vez, es posible que se le pida que dé su consentimiento a permisos específicos.

  2. Inicie sesión en el sitio de administración de WordPress con el nombre de usuario y la contraseña que especificó al crear WordPress en App Service.

  3. En el menú de la izquierda, seleccione Apariencia>Temas y, a continuación, Agregar nuevo tema.

  4. Seleccione Cargar tema. Seleccione Elegir archivo para cargar el archivo ZIP del tema del portal para desarrolladores de API Management que descargó anteriormente. Seleccione Instalar.

  5. En la pantalla siguiente, seleccione Reemplazar activo por cargado.

  6. Si se le solicita, seleccione Activar.

Nota:

Si el sitio de WordPress incluye un complemento de almacenamiento en caché, borre la caché después de activar el tema para asegurarse de que los cambios surtan efecto.

Paso 7: Instalación del complemento del portal para desarrolladores

  1. En el sitio de administración de WordPress, en el menú izquierdo, seleccione Complementos>Agregar nuevo complemento.
  2. Seleccione Cargar complemento. Seleccione Elija archivo para cargar el archivo ZIP del complemento del portal para desarrolladores de API Management (apim-devportal.zip) que descargó anteriormente. Seleccione Instalar.
  3. Después de la instalación correcta, seleccione Activar complemento.
  4. En el menú izquierdo, seleccione Portal para desarrolladores de Azure API Management.
  5. En la página Configuración de APIM, escriba la siguiente configuración y seleccione Guardar cambios:
    • Nombre del servicio APIM: Nombre de la instancia de API Management
    • Habilitar Crear páginas predeterminadas y menú crear navegación

Paso 8: Agregar una hoja de estilos personalizada

Agregue una hoja de estilos personalizada para el portal para desarrolladores de API Management.

  1. En el sitio de administración de WordPress, en el menú izquierdo, seleccione Apariencia>Temas.

  2. Seleccione Personalizar y vaya a Estilos.

  3. Seleccione el icono de lápiz (Editar estilos).

  4. En el panel Estilos, seleccione Más (tres puntos) >CSS adicional.

  5. En CSS adicional, escriba el siguiente CSS:

    .apim-table {
      width: 100%;
      border: 1px solid #D1D1D1;
      border-radius: 4px;
      border-spacing: 0;
    }
    
    .apim-table th {
      background: #E6E6E6;
      font-weight: bold;
      text-align: left;
    }
    
    .apim-table th,
    .apim-table td {
      padding: .7em 1em;
    }
    
    .apim-table td {
      border-top: #E6E6E6 solid 1px;
    }
    
    .apim-input,
    .apim-button,
    .apim-nav-link-btn {
        border-radius: .33rem;
        padding: 0.6rem 1rem;
    }
    
    .apim-button,
    .apim-nav-link-btn {
        background-color: var(--wp--preset--color--contrast);
        border-color: var(--wp--preset--color--contrast);
        border-width: 0;
        color: var(--wp--preset--color--base);
        font-size: var(--wp--preset--font-size--small);
        font-weight: 500;
        text-decoration: none;
        cursor: pointer;
        transition: all .25s ease;
    }
    
    .apim-nav-link-btn:hover {
        background: var(--wp--preset--color--base);
        color: var(--wp--preset--color--contrast);
    }
    
    .apim-button:hover {
        background: var(--wp--preset--color--vivid-cyan-blue);
    }
    
    .apim-button:disabled {
        background: var(--wp--preset--color--contrast-2);
        cursor: not-allowed;
    }
    
    .apim-label {
        display: block;
        margin-bottom: 0.5rem;
    }
    
    .apim-input {
        border: solid 1px var(--wp--preset--color--contrast);
    }
    
    .apim-grid {
        display: grid;
        grid-template-columns: 11em max-content;
    }
    
    .apim-link,
    .apim-nav-link {
        text-align: inherit;
        font-size: inherit;
        padding: 0;
        background: none;
        border: none;
        font-weight: inherit;
        cursor: pointer;
        text-decoration: none;
        color: var(--wp--preset--color--vivid-cyan-blue);
    }
    
    .apim-nav-link {
        font-weight: 500;
    }
    
    .apim-link:hover,
    .apim-nav-link:hover {
        text-decoration: underline;
    }
    
    #apim-signIn {
        display: flex;
        align-items: center;
        gap: 24px;
    }
    
  6. Guarde los cambios. Seleccione Guardar de nuevo para guardar los cambios en el tema.

  7. Cerrar sesión del sitio de administración de WordPress.

Paso 9: Iniciar sesión en el portal para desarrolladores de API Management implementado en WordPress

Inicie sesión en el sitio de WordPress para ver el nuevo portal para desarrolladores de API Management implementado en WordPress y hospedado en App Service.

Nota:

Solo puede iniciar sesión en el portal para desarrolladores en WordPress con las credenciales de id. de Microsoft Entra. No se admite la autenticación básica.

  1. En una nueva ventana del explorador, vaya al sitio de WordPress y sustituya el nombre del servicio de aplicaciones en la siguiente dirección URL: https://<yourapp-service-name>.azurewebsites.net
  2. Cuando se le solicite, inicie sesión con las credenciales de Microsoft Entra ID para una cuenta de desarrollador.

Ahora puede usar las siguientes características del portal para desarrolladores de API Management:

  • Inicio de sesión en el portal
  • Vea la lista de API.
  • Vaya a la página de detalles de la API y vea la lista de operaciones.
  • Prueba de la API mediante claves de API válidas
  • Ver lista de productos
  • Suscribirse a un producto y generar claves de suscripción
  • Vaya a pestaña Perfil con los detalles de la cuenta y la suscripción.
  • Cerrar sesión en el portal

En la captura de pantalla siguiente se muestra una página de ejemplo del portal para desarrolladores de API Management hospedado en WordPress.

Captura de pantalla del portal para desarrolladores hospedado en WordPress.

Solución de problemas

No veo las páginas más recientes del portal para desarrolladores en el sitio de WordPress

Si no ve las páginas más recientes del portal para desarrolladores al visitar el sitio de WordPress, compruebe que el complemento del portal para desarrolladores está instalado, activado y configurado en el sitio de administración de WordPress. Vea Instalación del complemento del portal para desarrolladores para ver los pasos.

También es posible que tenga que borrar la memoria caché en el sitio de WordPress o en la red CDN, si se configura una. Como alternativa, es posible que tenga que borrar la memoria caché en el explorador.

Tengo problemas para iniciar sesión o salir del portal para desarrolladores

Si tiene problemas para iniciar o cerrar sesión en el portal para desarrolladores, borre la caché del explorador o vea el sitio del portal para desarrolladores en una sesión de explorador independiente (mediante el modo de exploración privada o incógnito).

No veo un botón de inicio de sesión en la barra de navegación del portal para desarrolladores

Si usa un tema personalizado diferente del proporcionado en el repositorio de complementos, es posible que tenga que agregar la funcionalidad de inicio de sesión a la barra de navegación manualmente. En la página Principal, agregue el siguiente bloque shortcode: [SignInButton]. Obtenga más información en la documentación de WordPress.

También puede iniciar sesión o cerrar sesión manualmente escribiendo las siguientes direcciones URL en el explorador:

  • Iniciar sesión: https://<app-service-name>.azurewebsites.net/.auth/login/aad
  • Cerrar sesión: https://<app-service-name>.azurewebsites.net/.auth/logout