Compartir vía


Guía de implementación del SDK de Aplicaciones para Windows para aplicaciones empaquetadas dependientes del marco

En este artículo se proporcionan instrucciones sobre la implementación de aplicaciones empaquetadas dependientes del marco (consulte ¿Qué es MSIX?) que usan el SDK de Aplicaciones para Windows. El tema equivalente para otras opciones de empaquetado dependientes del marco es SDK de Aplicaciones para Windows guía de implementación para aplicaciones dependientes del marco empaquetadas con ubicación externa o sin empaquetar.

Información general

De forma predeterminada, cuando se crea un proyecto con una de las plantillas de WinUI 3 en Visual Studio, el proyecto está configurado para compilar la aplicación en un paquete MSIX mediante MSIX de un solo proyecto (consulte Empaquetar la aplicación mediante MSIX de un solo proyecto) o un proyecto de empaquetado de aplicaciones de Windows (consulte Configuración de la aplicación de escritorio para el empaquetado MSIX en Visual Studio). A continuación, puedes compilar un paquete MSIX para tu aplicación mediante las instrucciones de Empaquetar una aplicación de escritorio o UWP en Visual Studio. Después de compilar un paquete MSIX para la aplicación, tiene varias opciones para administrar la implementación de MSIX.

Para obtener más información sobre los paquetes que puede necesitar la aplicación empaquetada cuando usa el SDK de Aplicaciones para Windows, consulte Arquitectura de implementación para la SDK de Aplicaciones para Windows. Entre ellos se incluyen los paquetes Framework, Main y Singleton , que están firmados y publicados por Microsoft. Hay dos requisitos principales para implementar una aplicación empaquetada:

  1. Implemente el paquete de marco de SDK de Aplicaciones para Windows.
  2. Llame a la API de implementación.

Requisitos previos

Implementación del paquete de marco de SDK de Aplicaciones para Windows

El paquete de marco de SDK de Aplicaciones para Windows contiene los archivos binarios de SDK de Aplicaciones para Windows usados en tiempo de ejecución y se instala con la aplicación. El marco tiene diferentes requisitos de implementación para distintos canales del SDK de Aplicaciones para Windows.

Versión estable

Al instalar una versión de versión estable (vea Notas de la versión del canal estable) del paquete NuGet de SDK de Aplicaciones para Windows en el equipo de desarrollo y crea un proyecto con una de las plantillas de proyecto de WinUI 3 proporcionadas, el manifiesto del paquete generado contiene un elemento PackageDependency que especifica una dependencia en el paquete de marco.

Sin embargo, si compila manualmente el paquete de la aplicación mediante un proyecto de empaquetado de aplicaciones de Windows independiente, debe declarar una PackageReference en el Application (package).wapproj archivo, como se indica a continuación:

<ItemGroup>
   <PackageReference Include="Microsoft.WindowsAppSDK" Version="1.0.1">
       <IncludeAssets>build</IncludeAssets>
   </PackageReference>
</ItemGroup>

Esa dependencia de paquete garantiza que el paquete framework se instala cuando la aplicación se implementa en otro equipo.

Versión preliminar

Al instalar una versión preliminar (consulte Notas de la versión preliminar del canal) del paquete NuGet de SDK de Aplicaciones para Windows en el equipo de desarrollo, se implementa una versión preliminar del paquete de marco de SDK de Aplicaciones para Windows durante el tiempo de compilación como una dependencia de paquete NuGet.

Llamada a la API de implementación

Consulte También Inicializar el SDK de Aplicaciones para Windows.

La API de implementación la proporciona el paquete de marco de SDK de Aplicaciones para Windows y está disponible en el espacio de nombres Microsoft.Windows.ApplicationModel.WindowsAppRuntime. El modelo de aplicación de Windows no admite la declaración de una dependencia en los paquetes Main y Singleton. Por lo tanto, la API de implementación es necesaria por estos motivos:

  1. Para implementar el paquete Singleton para características que no están en el paquete framework (por ejemplo, notificaciones push).
  2. Para implementar el paquete Main, que permite las actualizaciones automáticas del paquete framework desde Microsoft Store.

En el caso de las aplicaciones empaquetadas que no se distribuyen a través de la Tienda, como desarrollador es responsable de distribuir el paquete framework. Se recomienda llamar a la API de implementación para que se entreguen las actualizaciones de mantenimiento críticas. Tenga en cuenta que, para usar características fuera del paquete de Framework (por ejemplo, notificaciones push), se debe implementar el paquete Singleton (esto se puede hacer con la API de implementación o redistribuyendo los paquetes MSIX mediante su propio método de instalación).

Importante

En SDK de Aplicaciones para Windows versión 1.0, solo las aplicaciones empaquetadas que son de plena confianza o que tienen la funcionalidad restringida packageManagement tienen el permiso para usar la API de implementación para instalar las dependencias del paquete Main y Singleton. La compatibilidad con aplicaciones empaquetadas de confianza parcial estará disponible en versiones posteriores.

Debes llamar a deployment API después de inicializar el proceso de la aplicación, pero antes de que la aplicación use SDK de Aplicaciones para Windows características en tiempo de ejecución que usan el paquete Singleton (por ejemplo, notificaciones push). Los métodos principales de deployment API son los métodos estáticos GetStatus e Initialize de la clase DeploymentManager .

  • El método GetStatus devuelve el estado de implementación actual del entorno de ejecución de SDK de Aplicaciones para Windows que está cargado actualmente. Use este método para identificar si hay trabajo necesario para instalar SDK de Aplicaciones para Windows paquetes en tiempo de ejecución antes de que la aplicación actual pueda usar SDK de Aplicaciones para Windows características.
  • El método Initialize comprueba si todos los paquetes necesarios están presentes en una versión mínima necesaria para el entorno de ejecución de SDK de Aplicaciones para Windows que está cargado actualmente. Si faltan dependencias de paquetes, el método intenta registrar esos paquetes que faltan. A partir de SDK de Aplicaciones para Windows 1.1, el método Initialize también admite la opción de forzar la implementación de los paquetes en tiempo de ejecución de SDK de Aplicaciones para Windows. Esto cierra los procesos de los paquetes en tiempo de ejecución main y singleton y, por tanto, interrumpe sus servicios (por ejemplo, las notificaciones push no entregarán notificaciones durante este tiempo).

Aplicación de ejemplo de API de implementación

Para obtener instrucciones adicionales sobre cómo usar los métodos GetStatus e Initialize de la clase DeploymentManager , explore la aplicación de ejemplo disponible.

Solucionar errores de instalación

Si la API de implementación encuentra un error durante la instalación de los paquetes en tiempo de ejecución de SDK de Aplicaciones para Windows, devuelve un código de error que describe el problema.

Por ejemplo, si la aplicación no es de plena confianza o no tiene la funcionalidad restringida packageManagement , obtendrá un código de error ACCESS_DENIED . Para revisar otros códigos de error que pueden surgir y sus posibles causas, consulte Solución de problemas de empaquetado, implementación y consulta de aplicaciones de Windows.

Si el código de error no proporciona suficiente información, puede encontrar más información de diagnóstico en los registros de eventos detallados (consulte Obtener información de diagnóstico).

Si encuentra errores que no se pueden diagnosticar, registre un problema en el repositorio de GitHub de WindowsAppSDK con el código de error y los registros de eventos para que podamos investigar el problema.