Problemi relativi alla configurazione del server e del client nelle distribuzioni ClickOnce
Aggiornamento: novembre 2007
Se si utilizza Internet Information Services (IIS) su Windows Server 2003 e la distribuzione contiene un file il cui tipo non è riconosciuto da Windows, ad esempio un file di Microsoft Word, la trasmissione del file non sarà consentita e verrà generato un errore durante la distribuzione.
Inoltre, determinati server Web e software applicativi Web, ad esempio ASP.NET, contengono un elenco di file e tipi di file di cui non è consentito il download. ASP.NET, ad esempio, impedisce il download di tutti i file Web.config. Tali file possono contenere informazioni riservate quali i nomi utente e le password.
Anche se questa limitazione non causa in genere problemi per il download dei file più importanti di ClickOnce, ad esempio manifesti e assembly, può impedire il download di file di dati inclusi nell'applicazione ClickOnce. In ASP.NET è possibile risolvere questo errore rimuovendo il gestore che impedisce il download di questi file da Gestione configurazione IIS. Per ulteriori informazioni, vedere la documentazione relativa al server IIS.
È possibile che alcuni server Web blocchino i file con estensioni dll, config e mdf. Nelle applicazioni per Windows, tuttavia, sono normalmente inclusi file con queste estensioni. Se quindi un utente prova a eseguire un'applicazione ClickOnce che deve accedere a un file bloccato su un server Web, verrà restituito un errore. Per evitare che vengano sbloccate tutte le estensioni di file, per impostazione predefinita ogni file di applicazione viene pubblicato da ClickOnce con estensione deploy. L'amministratore pertanto dovrà solo configurare il server Web per sbloccare le tre estensioni di file seguenti:
.application
.manifest
.deploy
È tuttavia possibile disattivare questa opzione deselezionando la casella di controllo Usa estensione ".deploy" nella Finestra di dialogo Opzioni di pubblicazione. In tal caso sarà necessario configurare il server Web in modo da sbloccare tutte le estensioni di file utilizzate nell'applicazione.
Sarà ad esempio necessario configurare le estensioni manifest, application e deploy se si utilizza una versione di IIS in cui non è stato installato .NET Framework oppure se si utilizza un altro server Web quale Apache.
ClickOnce e SSL (Secure Sockets Layer)
Un'applicazione ClickOnce funziona correttamente su SSL, ad eccezione dei casi in cui Internet Explorer genera una richiesta sul certificato SSL. Tale richiesta può essere generata se il certificato presenta dei problemi, ad esempio se i nomi dei siti non corrispondono o se il certificato è scaduto. Per far sì che ClickOnce funzioni su una connessione SSL, accertarsi che il certificato sia aggiornato e che i dati del certificato corrispondano ai dati del sito.
ClickOnce e autenticazione proxy
ClickOnce fornisce supporto per l'autenticazione del proxy integrata di Windows. Non sono richieste specifiche direttive machine.config. ClickOnce non fornisce supporto per altri protocolli di autenticazione ad esempio di base o digest.
Per ulteriori informazioni, vedere Elemento <defaultProxy> (Impostazioni di rete).
ClickOnce e compatibilità con i browser Web
Le installazioni ClickOnce attualmente si avviano solo se l'URL del manifesto di distribuzione viene aperto utilizzando Internet Explorer. Una distribuzione il cui URL viene avviato da un'altra applicazione, ad esempio Microsoft Office Outlook, si avvierà solo se Internet Explorer è impostato come browser Web predefinito.
Nota: |
---|
È supportato anche Mozilla Firefox, ma solo se il provider di distribuzione non è vuoto ed è installato il plug-in ClickOnce per Firefox. |
Attivazione delle applicazioni ClickOnce tramite scripting di browser
Se è stata sviluppata una pagina Web personalizzata che avvia un'applicazione ClickOnce con scripting attivo, è possibile che in alcuni computer l'applicazione non si avvii. In Internet Explorer è disponibile un'impostazione denominata Richiesta di conferma automatica per download di file che influisce su questo comportamento. Questa impostazione è disponibile nella Scheda Sicurezza nel menu Opzioni che influisce su questo comportamento. È denominata Richiesta di conferma automatica per download di file ed è elencata sotto la categoria Download. Per impostazione predefinita, la proprietà è impostata su Attiva per le pagine Web Intranet e su Disattiva per le pagine Web Internet. Quando questa impostazione è impostata su Disattiva, qualsiasi tentativo di attivare un'applicazione ClickOnce a livello di codice (ad esempio, assegnando il relativo URL alla proprietà document.location ) verrà bloccato. In queste circostanze, gli utenti possono avviare applicazioni solo tramite un download iniziato dall'utente, ad esempio, facendo clic su un insieme di collegamenti ipertestuali all'URL dell'applicazione.
Altri problemi relativi alla configurazione del server
Autorizzazioni dell'amministratore richieste
È necessario disporre delle autorizzazioni di amministratore sul server di destinazione se si esegue la pubblicazione con HTTP. IIS richiede questo tipo di autorizzazione. Se invece non si utilizza HTTP, è necessario disporre solo dell'autorizzazione di scrittura sul percorso di destinazione.
Problemi relativi all'autenticazione del server
Quando si pubblica in un server remoto con l'accesso anonimo disattivato, viene visualizzato il seguente avviso:
"The files could not be downloaded from http://<remoteserver>/<myapplication>/. The remote server returned an error: (401) Unauthorized."
Nota: |
---|
È possibile far funzionare l'autenticazione NTLM (In attesa/Risposta NT) se il sito chiede credenziali diverse rispetto a quelle predefinite, e, nella finestra di dialogo relativa alla sicurezza, si sceglie OK per salvare le credenziali fornite per le sessioni future. Questa soluzione tuttavia non è efficace per l'autenticazione di base. |
Utilizzo di server Web di terze parti
Quando si distribuisce un'applicazione ClickOnce da un server Web diverso da IIS, è possibile che si verifichi un problema se il server restituisce il tipo di contenuto non corretto per i file ClickOnce più importanti, ad esempio il manifesto di distribuzione e quello dell'applicazione. Per risolvere questo problema, vedere la documentazione del server Web sull'aggiunta di nuovi tipi di contenuto al server e assicurarsi che siano presenti tutti i mapping delle estensioni dei nomi di file elencati nella tabella riportata di seguito.
Estensione del nome file |
Tipo di contenuto |
---|---|
.application |
application/x-ms-application |
.manifest |
application/x-ms-manifest |
.deploy |
application/octet-stream |
Protocollo FTP non supportato per l'installazione di applicazioni
ClickOnce supporta l'installazione di applicazioni da qualsiasi file server o server Web HTTP 1.1. Il protocollo FTP non è supportato per l'installazione di applicazioni. È possibile utilizzare il protocollo FTP solo per pubblicare applicazioni. Nella tabella riportata di seguito sono riepilogate tali differenze.
Tipo URL |
Descrizione |
---|---|
ftp:// |
È possibile pubblicare un'applicazione ClickOnce utilizzando questo protocollo. |
http:// |
È possibile installare un'applicazione ClickOnce utilizzando questo protocollo. |
https:// |
È possibile installare un'applicazione ClickOnce utilizzando questo protocollo. |
file:// |
È possibile installare un'applicazione ClickOnce utilizzando questo protocollo. |
Windows XP SP2: Windows Firewall
Per impostazione predefinita, Windows Firewall è attivato in Windows XP SP2. Se si sviluppa un'applicazione in un computer con sistema operativo Windows XP, sarà possibile pubblicare ed eseguire applicazioni ClickOnce dal server IIS locale, ma non sarà possibile accedere al server che esegue IIS da un altro computer a meno che non venga aperto Windows Firewall. Per istruzioni sulla gestione di Windows Firewall, vedere la Guida di Windows.
Windows Server 2003: attivazione delle estensioni del server di FrontPage
Per pubblicare applicazioni su un server Web Windows che utilizza HTTP, sono necessarie le estensioni del server di FrontPage 2002.
Per impostazione predefinita, le estensioni del server di FrontPage 2002 non sono installate in Windows Server 2003. Se si desidera utilizzare Visual Studio per pubblicare in un server Web Windows Server 2003 che utilizza HTTP con le estensioni del server di FrontPage 2002, è necessario innanzitutto installare queste ultime. Per l'esecuzione di questa operazione, in Windows Server 2003 è disponibile lo strumento Amministrazione server.
Windows Server 2003: tipi di contenuto bloccati
Se IIS viene eseguito su Windows Server 2003, vengono bloccati tutti i tipi di file tranne alcuni tipi di contenuto noti, ad esempio htm, html, txt e così via. Per consentire la distribuzione di applicazioni ClickOnce tramite questo server, è quindi necessario modificare le impostazioni di IIS per consentire il download dei file con estensione application e manifest e di eventuali altri tipi di file personalizzati utilizzati nell'applicazione.
Se si effettua la distribuzione tramite un server IIS, eseguire inetmgr.exe e aggiungere nuovi tipi di file per la pagina Web predefinita:
Per le estensioni application e manifest, il tipo MIME deve essere "application/x-ms-application". Per altri tipi di file, il tipo MIME deve essere "application/octet-stream".
Se si crea un tipo di file con estensione "*" e tipo MIME "application/octet-stream", sarà possibile scaricare file il cui tipo è sbloccato. I tipi di file bloccati, ad esempio quelli con estensione aspx e asmx, non potranno comunque essere scaricati.
Per istruzioni specifiche sulla configurazione dei tipi MIME in Windows 2003 Server, fare riferimento all'articolo KB326965, della Microsoft Knowledge Base, "IIS 6.0 non svolge i tipi sconosciuti MIME" all'indirizzo https://support.microsoft.com/default.aspx?scid=kb;it-it;326965.
Mapping dei tipi di contenuto
Quando si pubblica un'applicazione tramite HTTP, il tipo di contenuto, conosciuto anche come tipo MIME, relativo al file con estensione application deve essere "application/x-ms-application". Se nel server è installato .NET Framework 2.0, questo tipo verrà impostato automaticamente. In caso contrario, sarà necessario creare un'associazione al tipo MIME per la radice virtuale dell'applicazione ClickOnce, ossia per l'intero server.
Se si effettua la distribuzione utilizzando un server IIS, eseguire inetmgr.exe e aggiungere un nuovo tipo di contenuto "application/x-ms-application" per l'estensione application.
Problemi relativi alla compressione HTTP
In ClickOnce è possibile eseguire il download con compressione HTTP, una tecnologia per server Web basata sull'algoritmo GZIP che consente di comprimere un flusso di dati prima di inviarli al client. Il flusso viene poi decompresso dal client, nel caso specifico ClickOnce, prima della lettura dei file.
Se si utilizza IIS, è possibile attivare facilmente la compressione HTTP, ma questa viene attivata solo per determinati tipi di file, ossia file HTML e file di testo. Per attivare la compressione per gli assembly (dll), i file XML (xml), i manifesti di distribuzione (application) e i manifesti delle applicazioni (manifest), è necessario aggiungere questi tipi di file all'elenco di tipi di file per la compressione in IIS. Fino a quando non vengono aggiunti i tipi di file alla distribuzione, verranno compressi solo i file di testo e HTML.
Per istruzioni dettagliate su IIS, vedere l'articolo "Come specificare i tipi per la compressione HTTP di un altro documento" della Knowledge Base in MSDN Online. A tale scopo, nella pagina di ricerca della Knowledge Base cercare "234497".
Vedere anche
Concetti
Risoluzione dei problemi relativi alle distribuzioni ClickOnce
Cenni preliminari sulla distribuzione ClickOnce