Sin dalla versione 3.0 le applicazioni Silverlight possono essere installate in locale con molta facilità, in modo che possano essere eseguite fuori dal browser, come se fossero applicazioni desktop tradizionali.
Nonostante il file XAP venga copiato ed eseguito in locale, tali applicazioni mantengono comunque un legame con il sito web dal quale sono state installate; questo ci permette di avere un modello estremamente semplice di deploy degli aggiornamenti sulle varie installazioni, con una modalità concettualmente simile a ClickOnce
(https://www.winfxitalia.com/script/165/Personalizzare-Installazione-Applicazioni-ClickOnce.aspx).
In Silverlight è sufficiente registrarsi all'evento CheckAndDownloadUpdateCompleted di Application ed utilizzare il metodo CheckAndDownloadUpdateAsync allo startup dell'applicazione.
public App() { this.Startup += this.Application_Startup; this.Exit += this.Application_Exit; this.UnhandledException += this.Application_UnhandledException; InitializeComponent(); Application.Current.CheckAndDownloadUpdateCompleted += new CheckAndDownloadUpdateCompletedEventHandler(Current_CheckAndDownloadUpdateCompleted); } void Current_CheckAndDownloadUpdateCompleted(object sender, CheckAndDownloadUpdateCompletedEventArgs e) { if (e.UpdateAvailable) MessageBox.Show("Aggiornamento disponibile. Riavviare l'applicazione"); } private void Application_Startup(object sender, StartupEventArgs e) { Application.Current.CheckAndDownloadUpdateAsync(); this.RootVisual = new Main(); }
Nel CheckAndDownloadUpdateCompleted abbiamo a disposizione il parametro CheckAndDownloadUpdateCompletedEventArgs la cui proprietà UpdateAvailable assume il valore True nel caso lo XAP presente sul sito web di origine sia più recente dell'attuale in esecuzione.
La chiamata del metodo CheckAndDownloadUpdateAsync attiva immediatamente il download del nuovo XAP senza la possibilità di controllo per l'utente; inoltre è a nostra cura implementare le dovute strategie per inibire o meno l'utilizzo dell'applicazione corrente nel caso questa sia stata aggiornata: per eseguire la nuova versione, infatti, l'app corrente deve essere necessariamente chiusa e riavviata manualmente dall'utente
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Routing statico e PreRendering in una Blazor Web App
Inizializzare i container in Azure Container Apps
Verificare la provenienza di un commit tramite le GitHub Actions
Usare un KeyedService di default in ASP.NET Core 8
Creare gruppi di client per Event Grid MQTT
Effettuare chiamate con versioning da Blazor ad ASP.NET Core
Creare form tipizzati con Angular
Elencare le container images installate in un cluster di Kubernetes
Eseguire operazioni con timeout in React
Implementare il throttling in ASP.NET Core
Evitare la script injection nelle GitHub Actions
Sfruttare lo stream rendering per le pagine statiche di Blazor 8