Quando in Angular utilizziamo oggetti HTML che accettano un URL (come un tag iframe, o un tag img) capita di dover impostarne l'attributo src in binding con un valore proveniente da una configurazione, da un servizio o altro ancora. Mettere in binding la stringa dell'URL con l'attributo causa un errore di sicurezza in Angular. Per aggirare il problema dobbiamo validare la stringa farla considerare valida dal motore di Angular per poi inserirla in un oggetto SafeUrl.
Angular offre un servizio già pronto per processare la stringa: DomSanitizer. Questo servizio offre il metodo bypassSecurityTrustResourceUrl che permette di creare un oggetto SafeUrl partendo dalla stringa senza eseguire nessun controllo. Questo metodo è comodo quando la stringa proviene da una fonte sicura, ma espone ad attacchi di XSS se la stringa proviene dall'input di un utente.
export class HmiComponent implements OnInit {
bindingUrl: SafeUrl;
constructor(private sanitizer: DomSanitizer) { }
ngOnInit() {
this.bindingUrl = this.sanitizer.bypassSecurityTrustResourceUrl('http://www.google.it'/]);
}
}Una volta ottenuto l'oggeto SafeUrl, possiamo metterlo in binding con l'attributo src come qualunque altro valore.
<iframe [src]="bindingUrl"></iframe>
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Definire il colore di una scrollbar HTML tramite CSS
Abilitare il rolling update su Azure Functions flex consumption
Fissare una versione dell'agent nelle pipeline di Azure DevOps
Utilizzare zizmor per rendere più sicuri i workflow di GitHub
Ridurre il reflow cambiando il CSS
Raggruppamento degli aggiornamenti di dipendenze tra directory in un monorepo con Dependabot
Abilitare automaticamente il force push di un gruppo su Azure DevOps
Blazor e Static Web Assets in .NET 10
Supportare la crittografia di ASP.NET Core con Azure Container App
Ricerca delle GitHub issue tramite operatori logici
Utilizzo di CSS Scroll Snap per realizzare un carousel
Semplificare i deployment con le label in Azure Container App




