Guida alla distribuzione di Windows App SDK per le app dipendenti dal framework in pacchetto con percorso esterno o non in pacchetto
Questo argomento fornisce indicazioni sulla distribuzione di app in pacchetto con posizione esterna o non in pacchetto e che usano Windows App SDK.
- Queste app sono app desktop (non app UWP).
- Possono essere scritti in un linguaggio .NET, ad esempio C#, o in C++.
- Per l'interfaccia utente, possono usare WinUI 3, WPF o WinForms o un altro framework dell'interfaccia utente.
Panoramica
Gli sviluppatori di app in pacchetto con posizione esterna e di app non in pacchetto sono responsabili della distribuzione dei pacchetti di runtime necessari di Windows App SDK agli utenti finali. A tale scopo è possibile eseguire il programma di installazione o installare direttamente i pacchetti MSIX. Queste opzioni sono descritte in modo più dettagliato nella sezione Distribuzione del runtime Windows App SDK di seguito.
Le app in pacchetto con posizione esterna e le app non in pacchetto hanno anche altri requisiti di runtime. È necessario inizializzare l'accesso al runtime Windows App SDK usando l'API del API del caricatore di avvio. Inoltre, se l'app usa altri pacchetti framework oltre a Windows App SDK, si può utilizzare l'API delle dipendenze dinamiche. Questi requisiti sono descritti in modo più dettagliato nella sezione Requisiti di runtime per le app in pacchetto con posizione esterna o non in pacchetto di seguito.
Prerequisiti
- Scaricare gli ultimi programmi di installazione & pacchetti MSIX.
- Per le app in pacchetto con posizione esterna o non in pacchetto, Visual C++ Redistributable è un requisito. Per altre informazioni, vedere Download supportati più recenti per Microsoft Visual C++ Redistributable.
- C#. È necessario .NET 6 o versione successiva. Per altre informazioni, vedere Download di .NET.
Prerequisiti aggiuntivi
- Le versioni sperimentali e di anteprima di Windows App SDK richiedono l'abilitazione del trasferimento locale per installare il runtime.
Il trasferimento locale è abilitato automaticamente in Windows 10, versione 2004 e successive.
Se il computer di sviluppo o il computer di distribuzione esegue Windows 11, verificare se il trasferimento locale è abilitato:
- Impostazioni>Privacy & sicurezza>Per sviluppatori. Assicurarsi che la modalità sviluppatore sia attivata.
Se il computer di sviluppo o il computer di distribuzione esegue Windows 10, versione 1909 o una versione precedente, verificare se il trasferimento locale è abilitato:
- Impostazioni>Aggiornamento & Sicurezza>Per sviluppatori>Usa le funzionalità per gli sviluppatori. Verificare che Sideload app o Modalità sviluppatore siano selezionate.
L'impostazione Modalità sviluppatore include il trasferimento locale e altre funzionalità.
Nota
Se il computer è gestito in un ambiente aziendale, potrebbe essere presente un criterio che impedisce la modifica di queste impostazioni. In tal caso, se si riceve un errore quando si tenta di installare il runtime di Windows App SDK, contattare il professionista IT per abilitare il trasferimento locale o la modalità sviluppatore.
Distribuzione del runtime di Windows App SDK
Le app in pacchetto con posizione esterno e le app non in pacchetto hanno due opzioni per distribuire il runtime di Windows App SDK:
- Opzione 1: usare il programma di installazione: il programma di installazione invisibile all'utente distribuisce tutti i pacchetti MSIX di Windows App SDK. Un programma di installazione separato è disponibile per ognuna delle architetture
X64
eX86
Arm64
. - Opzione 2: installare direttamente i pacchetti: è possibile usare il programma di installazione o lo strumento MSI esistente per installare i pacchetti MSIX di Windows App SDK.
Opzione 1: usare il programma di installazione
È possibile distribuire tutti i pacchetti di runtime di Windows App SDK eseguendo il programma di installazione. Il programma di installazione è disponibile in Download per Windows App SDK. Quando si esegue il programma di installazione (.exe), viene visualizzato un output simile al seguente:
Deploying package: Microsoft.WindowsAppRuntime.1.0_0.318.928.0_x64__8wekyb3d8bbwe
Package deployment result : 0x0
Deploying package: Microsoft.WindowsAppRuntime.1.0_0.318.928.0_x86__8wekyb3d8bbwe
Package deployment result : 0x0
Deploying package: MicrosoftCorporationII.WindowsAppRuntime.Main.1.0_0.318.928.0_x64__8wekyb3d8bbwe
Package deployment result : 0x0
Provisioning result : 0x0
Deploying package: Microsoft.WindowsAppRuntime.Singleton_0.318.928.0_x64__8wekyb3d8bbwe
Package deployment result : 0x0
Provisioning result : 0x0
Deploying package: Microsoft.WinAppRuntime.DDLM.0.318.928.0-x6_0.318.928.0_x64__8wekyb3d8bbwe
Package deployment result : 0x0
Provisioning result : 0x0
Deploying package: Microsoft.WinAppRuntime.DDLM.0.318.928.0-x8_0.318.928.0_x86__8wekyb3d8bbwe
Package deployment result : 0x0
Provisioning result : 0x0
All install operations successful.
È possibile eseguire il programma di installazione senza interazione dell'utente e eliminare tutto l'output di testo con l'opzione --quiet
:
WindowsAppRuntimeInstall.exe --quiet
È anche possibile scegliere di forzare l'aggiornamento dei pacchetti MSIX e arrestare qualsiasi processo di Windows App SDK attualmente in esecuzione usando l'opzione --force
. Questa funzionalità è stata introdotta nella versione 1.1.
WindowsAppRuntimeInstall.exe --force
Per visualizzare tutte le opzioni della riga di comando del programma di installazione, eseguire WindowsAppRuntimeInstall --h
.
Al termine dell'installazione, è possibile eseguire l'app in pacchetto con posizione esterna o non in pacchetto. Per un esempio di compilazione ed esecuzione di un'app in pacchetto con posizione esterna o non in pacchetto che usa Windows App SDK, vedere Esercitazione: usare l'API del programma di avvio automatico in un'app in pacchetto con posizione esterna o non in pacchetto che usa Windows App SDK.
Concatenare il programma di installazione di Windows App SDK alla configurazione dell'app
Se si dispone di un programma di installazione personalizzato per l'app, è possibile concatenare il processo di installazione di Windows App SDK al processo di installazione dell'app. Il programma di installazione di Windows App SDK attualmente non fornisce un'interfaccia utente predefinita, quindi si dovrà procedere alla concatenazione usando l'interfaccia utente personalizzata della configurazione.
È possibile avviare e rilevare automaticamente l'installazione di Windows App SDK mentre viene visualizzato lo stato di avanzamento dell'installazione usando ShellExecute. Il programma di installazione di Windows App SDK decomprime automaticamente il bundle Windows App MSIX e chiama il metodo PackageManager.AddPackageAsync per completare l'installazione. Questa operazione è molto simile ad altri programmi di installazione di runtime usati, ad esempio .NET, Visual C++ o DirectX.
Per un esempio di codice che mostra come eseguire il programma di installazione di Windows App SDK dal programma di installazione, vedere la funzione RunInstaller nei test funzionali del programma di installazione.
Esempio di programma di installazione
Vedere l'esempio seguente per vedere come avviare il programma di installazione da un programma di installazione Win32 senza aprire una finestra della console durante l'installazione:
Risoluzione dei problemi
Codici restituiti
Nella tabella seguente sono elencati i codici restituiti più comuni per il programma di installazione di Windows App SDK .exe. I codici restituiti sono gli stessi per tutte le versioni del programma di installazione.
Codice restituito | Descrizione |
---|---|
0x0 | L'installazione o il provisioning del pacchetto è stato completato correttamente. |
0x80073d06 | Impossibile installare uno o più pacchetti. |
0x80070005 | L'installazione o il provisioning a livello di sistema non è stato possibile perché l'app non è in esecuzione con privilegi elevati o l'utente che esegue l'installazione non dispone di privilegi di amministratore. |
Errori di installazione
Se il programma di installazione di Windows App SDK restituisce un errore durante l'installazione, restituirà un codice di errore che descrive il problema.
- Vedere l'elenco dei codici di errore comuni.
- Se il codice di errore non fornisce informazioni sufficienti, è possibile trovare altre informazioni di diagnostica nei log eventi dettagliati.
- Si prega di segnalare un problema con il codice di errore e i log eventi in modo che il problema possa essere analizzato.
Opzione 2: distribuire direttamente i pacchetti di runtime di Windows App SDK
In alternativa all'uso del programma di installazione di Windows App SDK per la distribuzione agli utenti finali, è possibile distribuire manualmente i pacchetti MSIX tramite il programma o l'MSI dell'app. Questa opzione può essere ideale per gli sviluppatori che vogliono avere un maggiore controllo.
Per un esempio che mostra come il programma di installazione può installare i pacchetti MSIX, vedere install.cpp nel codice del programma di installazione di Windows App SDK.
Per verificare se il SDK per app di Windows è già installato (e, in caso affermativo, quale versione), è possibile verificare la presenza di famiglie di pacchetti specifiche chiamando PackageManager.FindPackagesForUserWithPackageTypes.
Da un processo unpackaged mediumIL (full trust) (vedere Elemento Application), è possibile usare il codice seguente per verificare la presenza di un pacchetto registrato all'utente corrente:
using Windows.Management.Deployment;
public class WindowsAppSDKRuntime
{
public static IsPackageRegisteredForCurrentUser(
string packageFamilyName,
PackageVersion minVersion,
Windows.System.ProcessorArchitecture architecture,
PackageTypes packageType)
{
ulong minPackageVersion = ToVersion(minVersion);
foreach (var p : PackageManager.FindPackagesForUserWithPackageTypes(
string.Empty, packageFamilyName, packageType)
{
// Is the package architecture compatible?
if (p.Id.Architecture != architecture)
{
continue;
}
// Is the package version sufficient for our needs?
ulong packageVersion = ToVersion(p.Id.Version);
if (packageVersion < minPackageVersion)
{
continue;
}
// Success.
return true;
}
// No qualifying package found.
return false;
}
private static ulong ToVersion(PackageVersion packageVersion)
{
return ((ulong)packageVersion.Major << 48) |
((ulong)packageVersion.Minor << 32) |
((ulong)packageVersion.Build << 16) |
((ulong)packageVersion.Revision);
}
}
Per lo scenario precedente, chiamare FindPackagesForUserWithPackageTypes è preferibile chiamare FindPackagesForUser. Ciò è dovuto al fatto che è possibile restringere la ricerca a (per questo esempio), solo ai pacchetti framework o principali. E questo evita la corrispondenza di altri tipi di pacchetti (ad esempio , risorsa, facoltativa o bundle) che non sono di interesse per questo esempio.
Per usare il contesto utente corrente/chiamante, impostare il parametro userSecurityId su una stringa vuota.
E ora alcune informazioni utili per decidere come chiamare la funzione nell'esempio di codice precedente. Un runtime installato correttamente è costituito da più pacchetti che dipendono dall'architettura della CPU del sistema:
- In un computer x86: Fwk=[x86], Main=[x86], Singleton=[x86], DDLM=[x86].
- In un computer x64: Fwk=[x86, x64], Main=[x64], Singleton=[x64], DDLM=[x86, x64].
- In un computer arm64: Fwk=[x86, x64, arm64], Main=[arm64], Singleton=[arm64], DDLM=[x86, x64, arm64].
Per i pacchetti Main e Singleton , l'architettura deve corrispondere all'architettura della CPU del sistema, ad esempio pacchetti x64 in un sistema x64. Per il pacchetto Framework , un sistema x64 può eseguire app x64 e x86. Analogamente, un sistema arm64 può eseguire app arm64, x64 e x86. Un controllo del pacchetto DDLM è simile a un controllo framework, ad eccezione del fatto che PackageType=main
e packagefamilyname differisce e più di un nome packagefamilyname (diverso) possono essere applicabili, a causa dello schema di denominazione univoco di DDLM. Per altre info, vedi la specifica dei pacchetti MSIX. I controlli sono quindi più simili al seguente:
public static bool IsRuntimeRegisteredForCurrentUser(PackageVersion minVersion)
{
ProcessorArchitecture systemArchitecture = DetectSystemArchitecture();
return IsFrameworkRegistered(systemArchitecture, minVersion) &&
IsMainRegistered(systemArchitecture, minVersion) &&
IsSingletonRegistered(systemArchitecture, minVersion) &&
IsDDLMRegistered(systemArchitecture, minVersion);
}
private static ProcecssorArchitecture DetectSystemArchitecture()
{
// ...see the call to IsWow64Process2(), and how the result is used...
// ...as per `IsPackageApplicable()` in
// [install.cpp](https://github.com/microsoft/WindowsAppSDK/blob/main/installer/dev/install.cpp)
// line 99-116...
// ...WARNING: Use IsWow64Process2 to detect the system architecture....
// ... Other similar APIs exist, but don't give reliably accurate results...
}
private static bool IsFrameworkRegistered(ProcessorArchitecture systemArchitecture,
PackageVersion minVersion)
{
// Check x86.
if (!IsPackageRegisteredForCurrentUser(
global::Microsoft.WindowsAppSDK.Runtime.Packages.Framework.PackageFamilyName,
minVersion, ProcessorArchitecture.X86,
PackageTypes.Framework))
{
return false;
}
// Check x64 (if necessary).
if ((systemArchitecture == ProcessorArchitecture.X64) ||
(systemArchitecture == ProcessorArchitcture.Arm64))
{
if (!IsPackageRegisteredForCurrentUser(
global::Microsoft.WindowsAppSDK.Runtime.Packages.Framework.PackageFamilyName,
minVersion, ProcessorArchitecture.X64,
PackageTypes.Framework))
{
return false;
}
}
// Check arm64 (if necessary).
if (systemArchitecture == ProcessorArchitcture.Arm64)
{
if (!IsPackageRegisteredForCurrentUser(
global::Microsoft.WindowsAppSDK.Runtime.Packages.Framework.PackageFamilyName,
minVersion, ProcessorArchitecture.Arm64,
PackageTypes.Framework))
{
return false;
}
}
return true;
}
private static bool IsMainRegistered(ProcessorArchitecture systemArchitecture,
PackageVersion minVersion)
{
return IsPackageRegisteredForCurrentUser(
global::Microsoft.WindowsAppSDK.Runtime.Packages.Main.PackageFamilyName,
minVersion,
systemArchitecture,
PackageTypes.Main);
}
private static bool IsSingletonRegistered(ProcessorArchitecture systemArchitecture,
PackageVersion minVersion)
{
return IsPackageRegisteredForCurrentUser(
global::Microsoft.WindowsAppSDK.Runtime.Packages.Singleton.PackageFamilyName,
minVersion,
systemArchitecture,
PackageTypes.Main);
}
private static bool IsDDLMRegistered(ProcessorArchitecture systemArchitecture,
PackageVersion minVersion)
{
// ...similar to IsFrameworkRegistered, but the packageFamilyName is more complicated...
// ...and no predefined constant is currently available...
// ...for more details, see
// https://github.com/microsoft/WindowsAppSDK/blob/main/specs/Deployment/MSIXPackages.md.
}
Le informazioni e il codice precedenti illustrano lo scenario di rilevamento di base. Per rilevare se viene effettuato il provisioning del runtime per tutti gli utenti o per eseguire le operazioni precedenti da un contenitore di app e/o eseguire questa operazione da un processo in mediumIL
pacchetto, è necessaria una logica aggiuntiva.
Scenari di distribuzione
Installazione del runtime di Windows App SDK a livello di sistema: l'installazione a livello di sistema modifica il computer per tutti gli utenti, inclusi i nuovi utenti che verranno aggiunti in futuro. Se l'app è in esecuzione con privilegi elevati e l'utente che esegue l'installazione disponde di privilegi di amministratore, il programma di installazione registrerà i pacchetti MSIX a livello di sistema chiamando ProvisionPackageForAllUsersAsync. Se la registrazione a livello di sistema ha esito negativo, l'installazione verrà eseguita solo per l'utente corrente che esegue l'installazione. In un ambiente aziendale gestito, l'amministratore IT deve essere in grado di effettuare il provisioning per tutti come al solito.
Architetture ridistribuite dal programma di installazione di SDK per app di Windows: il programma di installazione SDK per app di Windows è disponibile nelle
x86
architetture ,x64
eArm64
. Ogni versione del programma di installazione include i pacchetti MSIX solo per l'architettura specifica per cui è denominato. Ad esempio, se si esegue inx86
WindowsAppRuntimeInstall.exe
un dispositivo x64 o Arm64, talex86
programma di installazione verrà distribuito in tale dispositivo solo i pacchetti per l'architettura x86.Tutti i pacchetti MSIX di Windows App SDK sono già installati sul computer: i pacchetti MSIX vengono installati in una posizione a livello di sistema con una sola copia su disco. Se un'app tenta di installare Windows App SDK quando tutte le dipendenze del pacchetto MSIX sono già installate sul computer, l'installazione non viene eseguita.
Uno o più pacchetti MSIX di Windows App SDK non sono installati sul computer: quando si distribuisce Windows App SDK, tentare sempre di installare tutti i pacchetti MSIX (framework, main, singleton, DDLM) per assicurarsi che tutte le dipendenze siano installate e che non ci siano interruzioni dell'esperienza dell'utente finale.
Requisiti di runtime per le app in pacchetto con posizione esterna o non in pacchetto
Le app in pacchetto con posizione esterna o non in pacchetto hanno requisiti di runtime aggiuntivi per l'uso del runtime di Windows App SDK. Questo implica il riferimento e l'inizializzazione del pacchetto framework di Windows App SDK in fase di runtime. Inoltre, l'API delle dipendenze dinamiche può essere usata per fare riferimento ad altri pacchetti di framework all'esterno di Windows App SDK.
Usare il runtime di Windows App SDK
Le app in pacchetto con posizione esterna e non in pacchetto devono chiamare l'API del programma di avvio automatico per usare Windows App SDK in fase di runtime. Questa operazione è necessaria prima che l'app possa usare le funzionalità di Windows App SDK WinUI, Ciclo di vita dell'app, MRT Core e DWriteCore. Un componente del programma di avvio automatico consente alle app in pacchetto con posizione esterna e non in pacchetto per eseguire queste importanti attività:
- Trovare e caricare il pacchetto framework di Windows App SDK nel grafico dei pacchetti dell'app.
- Inizializzare il Dynamic Dependency Lifetime Manager (DDLM) per il pacchetto framework di Windows App SDK. Lo scopo del DDLM è impedire la manutenzione del pacchetto framework di Windows App SDK mentre è usato da un'app in pacchetto con percorso esterno o non in pacchetto.
Il modo più semplice per caricare il runtime di Windows App SDK per le app con in pacchetto con posizione esterna e non in pacchetto consiste nell'impostare la proprietà <WindowsPackageType>None</WindowsPackageType>
nel file di progetto (con estensione csproj o .vcxproj). È anche possibile chiamare l'API del programma di avvio automatico direttamente nel codice di avvio dell'app per un maggiore controllo sull'inizializzazione. Per informazioni dettagliate, vedere Usare il runtime di Windows App SDK per le app in pacchetto con posizione esterna o non in pacchetto ed Esercitazione: usare l'API del programma di avvio automatico in un'app in pacchetto con posizione esterna o non in pacchetto che usa Windows App SDK.
Il supporto delle dipendenze dinamiche consente alle app in pacchetto con posizione esterna e non in pacchetto di mantenere il meccanismo di distribuzione esistente, ad esempio MSI o qualsiasi programma di installazione, oltre a poter sfruttare Windows App SDK nell'applicazione. Le dipendenze dinamiche possono essere usate nella app in pacchetto, nelle app in pacchetto con posizione esterna e nelle app non in pacchetto; anche se sono destinate principalmente a essere usato dalle app in pacchetto con posizione esterna e non in pacchetto.
È disponibile un DDLM per ogni versione e architettura del pacchetto framework di Windows App SDK. Ciò significa che in un x64
computer, è possibile che sia una versione x86
e una versione x64
del DDLM a supportare app di entrambe le architetture.
Fare riferimento ad altri pacchetti framework usando l'API delle dipendenze dinamiche
Se si vogliono usare funzionalità in altri pacchetti framework all'esterno di Windows App SDK (ad esempio, DirectX), le app in pacchetto con posizione esterna e non in pacchetto può chiamare l'API delle dipendenze dinamiche. Oltre al componente del programma di avvio automatico, Windows App SDK fornisce anche un set più ampio di funzioni C/C++ e classi WinRT che implementano l'API delle dipendenze dinamiche. Questa API è progettata per fare riferimento a qualsiasi pacchetto framework in modo dinamico in fase di runtime.
Per altre informazioni, vedere Usare pacchetti framework MSIX in modo dinamico dall'app desktop e l'esempio di dipendenze dinamiche
Distribuire file .winmd nel computer di destinazione
Insieme all'app, è consigliabile procedere e distribuire i file Windows Metadata (.winmd
). I metadati possono essere usati da varie API e comportamenti in fase di runtime; la loro assenza può limitare o interromperne le funzionalità. Ad esempio, i metadati possono essere usati per effettuare il marshalling degli oggetti nei limiti degli apartment; e la necessità di effettuare il marshalling può essere una funzione delle prestazioni del computer. Poiché non esiste un modo deterministico per sapere se sono necessari metadati, è consigliabile distribuirli .winmd
, a meno che non si sia estremamente preoccupati per le dimensioni.
Argomenti correlati
- Guida alla distribuzione di Windows App SDK per le app in pacchetto dipendenti dal framework
- Esercitazione: usare l'API del programma di avvio automatico in un'app in pacchetto con percorso esterno o non in pacchetto che usa Windows App SDK
- Verificare le versioni installate del runtime di Windows App SDK
- Rimuovere le versioni di runtime di Windows App SDK obsolete dal computer di sviluppo