>백엔드 개발 >PHP 튜토리얼 >Laravel의 블레이드 템플릿 엔진에서 HTML을 안전하게 표시하려면 어떻게 해야 합니까?

Laravel의 블레이드 템플릿 엔진에서 HTML을 안전하게 표시하려면 어떻게 해야 합니까?

Susan Sarandon
Susan Sarandon원래의
2024-12-10 08:17:09301검색

How Can I Safely Display HTML in Laravel's Blade Templating Engine?

Blade를 사용하여 Laravel에서 안전하게 HTML 표시

Laravel에서 원시 HTML 코드를 표시하면 보안 문제가 발생하고 예상치 못한 출력이 발생할 수 있습니다. 이것이 Laravel의 기본 템플릿 엔진인 Blade가 HTML 문자를 자동으로 이스케이프하는 이유입니다. 그러나 특정 시나리오에서는 원시 HTML을 표시해야 할 수도 있습니다.

문제: HTML 코드가 포함된 문자열을 표시하기 위해 {{ $text }}를 사용할 때 Blade는 대신 문자열을 이스케이프합니다. HTML로 렌더링합니다.

해결책: Blade로 HTML을 안전하게 표시하려면 {!! $텍스트 !!}. 이 구문은 Blade가 문자열을 원시 HTML로 렌더링하도록 합니다.

예:

$text = '<p><strong>Lorem</strong> ipsum dolor <img src="images/test.jpg"></p>';

HTML을 올바르게 표시하려면:

{!! $text !!}

데이터 탈출:

다음을 사용하는 것을 기억하세요. {!! $text !!}는 크로스 사이트 스크립팅 공격으로부터 보호하는 데 필수적인 HTML 이스케이프를 비활성화합니다. 그러므로 항상 {!!를 통해 렌더링하는 모든 HTML을 확인하세요. 데이터베이스 쿼리나 사용자 입력에서 가져온 데이터와 같은 $text !!}는 보안을 위해 삭제되고 검증됩니다.

위 내용은 Laravel의 블레이드 템플릿 엔진에서 HTML을 안전하게 표시하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.