Una delle limitazioni imposte dalla Universal Windows Platform è che, grazie alla sandbox e agli standard di sicurezza messi a disposizione dalla piattaforma, non è possibile accedere a contenuti che si trovano in posizioni diverse dalle cartella Documenti, Foto e Video. Con l'ultimo update di Windows 10, è stata aggiunta una nuova capability, chiamata broadFileSystemAccess che serve proprio ad ovviare a questo problema e permette la scrittura in una parte qualsiasi del filesystem a cui l'utente stesso che sta eseguendo l'applicazione ha accesso.
Per aggiungere questa capability, è necessario aggiungere anche il namespace dedicato all'interno del file Package.appxmanifest:
xmlns:rescap="http://schemas.microsoft.com/appx/manifest/foundation/windows10/restrictedcapabilities" IgnorableNamespaces="uap mp rescap" <!-- --> <Capabilities> <rescap:Capability Name="broadFileSystemAccess" /> </Capabilities>
Come si può notare, però, questo nuovo namespace fa parte delle restricted capability: qualora l'applicazione venga distribuita tramite lo store, verrà eseguito un ulteriore passaggio di analisi prima della pubblicazione e verrà richiesto il motivo per la quale l'applicazione richiede questo particolare accesso e quali benefici porterà agli utenti.
Una volta configurato il file di manifest, si può richiedere l'accesso ad un qualsiasi percorso di sistema (tenendo cura dei permessi di accesso) ed elencare, come dimostra l'esempio seguente, tutti i file presenti nelle cartelle (ed eventuali sotto-cartelle):
protected override async void OnNavigatedTo(NavigationEventArgs e) { await GetFiles(@"C:\Users\aspitalia\Desktop"); } private async Task GetFiles(string path) { if (string.IsNullOrEmpty(path)) return; try { var folder = await StorageFolder.GetFolderFromPathAsync(path); var folders = await folder.GetFoldersAsync(); foreach (StorageFolder directory in folders) { var files = await directory.GetFilesAsync(); foreach (StorageFile file in files) { Debug.WriteLine($"Found {file.Name} in {directory.Name}"); } } } catch (Exception ex) { Debug.WriteLine(ex.Message); } }
Le API messe a disposizione dal framework sono identiche a quelle già utilizzate in precedenza per accedere, ad esempio, alla cartella Documenti, pertanto non è necessario andare a personalizzare eventuale codice pre-esistente.
Il codice sorgente di questo script è disponibile su GitHub al seguente indirizzo https://github.com/aspitalia/scripts-windows/tree/master/script-200
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Gestire la cancellazione di una richiesta in streaming da Blazor
Eseguire query manipolando le liste contenute in un oggetto mappato verso una colonna JSON
Creare una custom property in GitHub
Applicare un filtro per recuperare alcune issue di GitHub
Creare gruppi di client per Event Grid MQTT
Creazione di plugin per Tailwind CSS: espandere le funzionalità del framework dinamicamente
Creare un webhook in Azure DevOps
Proteggere le risorse Azure con private link e private endpoints
Sfruttare al massimo i topic space di Event Grid MQTT
Ottimizzare le performance delle collection con le classi FrozenSet e FrozenDictionary
Gestire eccezioni nei plugin di Semantic Kernel in ASP.NET Core Web API
Le novità di Angular: i miglioramenti alla CLI
I più letti di oggi
- Microsoft aggiorna WinFS beta 1 per VS 2005
- Utilizzare CLEditor per consentire l'input di HTML in ASP.NET MVC
- Build 2015: segui con noi tutte le novità per gli sviluppatori in diretta da San Francisco
- VS 2005 e SQL Server 2005 Express da scaricare
- WS-I approva Basic Profile 1.0
- Utilizzare il metodo reduce in JavaScript