ClickOnce è una tecnologia che semplifica notevolmente la distribuzione delle applicazioni .NET mediante supporti fisici o web. E' completamente integrato in Visual Studio e si occupa di molteplici aspetti:
- Gestione dei permessi e dei requisiti dell'applicazione;
- Installazione senza diritti amministrativi;
- Aggiornamenti automatici;
- Controllo dell'integrità e del versioning;
Il tutto è supportato poi da API .NET contenute nell'assembly System.Deployment che permettono di intervenire, di monitorare gli aggiornamenti e di eseguirli in background. A causa della sua semplicità però fornisce un processo di installazione limitato nelle azioni che può eseguire e tra le richieste più comuni vi è senz'altro la necessità di personalizzare l'interfaccia di installazione.
Il motore non fornisce un sistema di template per la personalizzazione, come avviene per altri framework, ma permette la sostituzione totale dell'interfaccia. Per farlo bisogna prima di tutto recuperare il file app.manifest contenuto nella cartella Properties dell'applicazione; se non è presente è possibile farlo generare da Visual Studio andando nella sezione Security nelle proprietà del progetto
Localizzato il file all'interno del tag assembly va inserito il tag customUX:
<asmv1:assembly manifestVersion="1.0">
<assemblyIdentity version="1.0.0.0" name="MyApplication.app" />
<trustInfo xmlns="urn:schemas-microsoft-com:asm.v2">
<!-- omesso -->
</trustInfo>
<entryPoint xmlns="urn:schemas-microsoft-com:asm.v2">
<customUX xmlns="urn:schemas-microsoft-com:clickonce.v1" />
</entryPoint>
</asmv1:assembly>Con questo tag si impedisce di installare l'applicazione direttamente eseguendo il file .application. A questo punto occorre sviluppare un secondo applicativo che ha il solo scopo di gestire l'installazione mediante ClickOnce. Indipendentemente dall'interfaccia che si vuole utilizzare occorre sfruttare la classe InPlaceHostingManager per scaricare il manifest e mostrare i progressi di installazione mediante gli eventi GetManifestCompleted, DownloadProgressChanged e DownloadApplicationCompleted.
manager = new InPlaceHostingManager(new Uri(manifestUri), false); manager.GetManifestCompleted += new EventHandler<GetManifestCompletedEventArgs>(manager_GetManifestCompleted); manager.DownloadApplicationCompleted += new EventHandler<DownloadApplicationCompletedEventArgs>(manager_DownloadApplicationCompleted); // Ottengo il manifesto manager.GetManifestAsync();
Ottenuto il manifest è possibile leggerlo e asserire che le dipendenze e i requisiti di sicurezza sono soddisfatti. Successivamente con DownloadApplicationAsync si installa l'applicazione.
void manager_GetManifestCompleted(object sender, GetManifestCompletedEventArgs e)
{
// Requisiti soddisfatti
manager.AssertApplicationRequirements(true);
// Installo l'applicazione
manager.DownloadApplicationAsync();
}Al termine dell'installazione poiché il manifest è stato marcato con il customUX (operazione non obbligatoria) non si troverà nessuna voce di installazione nel pannello di controllo del sistema operativo, ne alcun collegamento sul desktop o nei menu. E' compito dell'installatore personalizzato eseguire eventualmente queste operazioni.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Abilitare automaticamente il force push di un gruppo su Azure DevOps
Pubblicare un MCP Server in GitHub MCP Registry
Escludere alcuni file da GitHub Copilot
Gestione dei prompt file a livello di organizzazione aziendale in GitHub
Le cron expression di un workflow di GitHub
Gestione delle issue type con GitHub
Ricerca delle GitHub issue tramite operatori logici
Raggruppamento degli aggiornamenti di dipendenze tra directory in un monorepo con Dependabot
Fissare una versione dell'agent nelle pipeline di Azure DevOps
Configurare automaticamente un webhook in Azure DevOps
Eseguire i pre-commit hook di git con dependabot
Self-healing degli unit test con Copilot in GitHub
I più letti di oggi
- Raggruppare i parametri di una minimal API in un singolo oggetto in ASP.NET Core
- Sapere il valore minimo e massimo di un valore in una query SQL
- Sfruttare le funzionalità del GPS con HTML5 e Geolocation API
- Leggere la posta usando il protocollo IMAP tramite la libreria MailKit
- Community Night@Basta!Italia on tour 2009 - Bologna
- Rilasciato Team Foundation Server e le versioni Express di Visual Studio 2008
- Rilasciata la versione 1.0 di ASP.NET MVC
- Due nuovi controlli ed esempi in VB nel Windows Phone Toolkit di febbraio 2011
- Disponibile la June 2011 CTP di Entity Framework




