ASP.NET regola l'accesso all'Url richiesto utilizzando un particolare HttpModule chiamato UrlAuthorizationModule, il quale ricava le regole applicate dalla sezione authorization del web.config.
È possibile impostare l'autorizzazione con il livello di granularità richiesto dalla nostra applicazione, utilizzando l'elemento location del web.config, prendendo ad esempio il seguente frammento:
<location path="OnlyForAdmin.txt" > <system.web> <authorization> <allow verbs="PUT" roles="Admin"/> <deny users="*"/> </authorization> </system.web> </location> <location path="OnlyForCommunityManager.txt" > <system.web> <authorization> <allow verbs="GET" roles="CommunityManager"/> <deny users="*" /> </authorization> </system.web> </location>
L'accesso ai due file di testo è stato limitato, mappando correttamente le estensioni in IIS questi saranno serviti solo ai ruoli specificati.
Al fine di impedire letture o scritture accidentali attraverso le classi di IO, come System.IO.File, è possibile utilizzare il metodo statico CheckUrlAccessForPrincipal della classe UrlAuthorizationModule.
if (UrlAuthorizationModule.CheckUrlAccessForPrincipal("/MyWebSite/OnlyForAdmin.txt", User, "PUT")) { InfoLabel.Text = "Posso accedere al file OnlyForAdmin.Txt"; //operazioni sul file... }
Il metodo accetta tre parametri, che sono il percorso relativo del file, un oggetto che implementi l'interfaccia IPrincipal, come ad esempio l'oggetto restituito dalla proprietà User della classe Page, ed infine una stringa che rappresenta l'accesso in sola lettura (GET, POST, HEAD) o scrittura (tutti gli altri).
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
I più letti di oggi
- Simulare Azure Cosmos DB in locale con Docker
- Utilizzare il metodo Index di LINQ per scorrere una lista sapendo anche l'indice dell'elemento
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!
- .NET Conference Italia 2024 - Milano
- .NET Conference Italia 2023 - Milano e Online