Nota
O acceso a esta páxina require autorización. Pode tentar iniciar sesión ou modificar os directorios.
O acceso a esta páxina require autorización. Pode tentar modificar os directorios.
En este artículo se proporcionan instrucciones sobre la implementación de aplicaciones empaquetadas dependientes del marco (consulte ¿Qué es MSIX?) que usan el Windows App SDK. El tema equivalente para otras opciones de empaquetado dependientes del marco es Windows App SDK guía de implementación para aplicaciones dependientes del marco empaquetadas con ubicación externa o sin empaquetar.
Overview
De forma predeterminada, al crear 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 Paquete la aplicación mediante MSIX de un solo proyecto) o un proyecto de empaquetado de aplicaciones de Windows (consulte Configurar 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 Paquete una aplicación de escritorio o UWP en Visual Studio. Después de compilar un paquete MSIX para tu aplicación, tienes varias opciones para Administrar tu implementación de MSIX.
Para obtener más información sobre los paquetes que la aplicación empaquetada podría necesitar cuando usa el Windows App SDK, consulte Arquitectura de implementación para la Windows App SDK. Entre ellos se incluyen los paquetes Framework, Main y Singleton ; todos firmados y publicados por Microsoft. Hay dos requisitos principales para implementar una aplicación empaquetada:
Prerequisites
- En el caso de las aplicaciones empaquetadas, la dependencia del paquete de marco VCLibs es un requisito. Para obtener más información, consulta paquetes del entorno de ejecución de C++ para Desktop Bridge.
- C#. se requiere .NET 6 o posterior. Para obtener más información, consulta .NET Descargas.
Implementación del paquete de marco de Windows App SDK
El paquete de marco de Windows App SDK contiene los archivos binarios Windows App SDK 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 Windows App SDK.
Versión estable
Al instalar una versión estable del paquete NuGet de Windows App SDK en el equipo de desarrollo y se crea un proyecto con una de las plantillas de proyecto winUI proporcionadas, el manifiesto del paquete generado contiene un PackageDependency elemento que especifica una dependencia en el paquete de marco.
Sin embargo, si compilas manualmente el paquete de la aplicación mediante un proyecto de empaquetado de aplicaciones de Windows independiente, debes declarar un
<ItemGroup>
<PackageReference Include="Microsoft.WindowsAppSDK" Version="1.8.260209005">
<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 del paquete NuGet de Windows App SDK en el equipo de desarrollo, se implementa una versión preliminar del paquete de marco de Windows App SDK durante el tiempo de compilación como dependencia de paquete NuGet.
Llamada a la API de implementación
Consulte también Initialize the Windows App SDK.
El paquete de framework de Windows App SDK proporciona la API de implementación y está disponible en el espacio de nombres Microsoft.Windows.ApplicationModel.WindowsAppRuntime. El modelo de aplicación 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:
- Para implementar el paquete Singleton para características que no están en el paquete framework (por ejemplo, notificaciones push).
- 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, usted, como el 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).
Important
Solo las aplicaciones empaquetadas que son de plena confianza o que tienen la funcionalidad restringida packageManagement tienen permiso para usar la API de implementación para instalar las dependencias del paquete Main y Singleton.
Debes llamar a la API de implementación después de que se haya inicializado el proceso de la aplicación, pero antes de que la aplicación use funciones de tiempo de ejecución de Windows App SDK que utilizan el paquete Singleton (por ejemplo, notificaciones push). Los métodos principales de la API de implementación son los métodos estáticos GetStatus y Initialize de la clase DeploymentManager.
- El método GetStatus devuelve el estado de implementación actual del entorno de ejecución de Windows App SDK que está cargado actualmente. Utilice este método para identificar si es necesario instalar paquetes de tiempo de ejecución de Windows App SDK antes de que la aplicación actual pueda usar las funciones de Windows App SDK.
- 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 Windows App SDK que está cargado actualmente. Si faltan dependencias de paquetes, el método intenta registrar esos paquetes que faltan. A partir de Windows App SDK 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 Windows App SDK. 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). Debe llamar a Initialize solo una vez. No es necesario llamar a Initialize para las aplicaciones implementadas a través de los comandos Iniciar sin depuración y Iniciar depuración en Visual Studio.
Important
El valor predeterminado de la propiedad Visual Studio <WindowsAppSdkDeploymentManagerInitialize> es true. Por lo tanto, si desea llamar a DeploymentManager.Initialize explícitamente, establezca <WindowsAppSdkDeploymentManagerInitialize>false</WindowsAppSdkDeploymentManagerInitialize> en el archivo de proyecto de Visual Studio.
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 Windows App SDK, 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 consultas 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 WindowsAppSDK GitHub repo con el código de error y los registros de eventos para que podamos investigar el problema.
Temas relacionados
Windows developer