
DOMDocument::loadHTML을 사용하여 HTML 문자열을 파싱할 때, 특수 문자가 포함되어 있는 경우에는 HTML 엔티티를 사용하여 처리해야 합니다.
예를 들어, `<`와 `>`는 HTML 엔티티로 `<`와 `>`로 표현됩니다.
#hostingforum.kr
php
$html = '
안녕하세요, 세계!';
$doc = new DOMDocument();
$doc->loadHTML($html);
echo $doc->saveHTML();
위 코드를 실행하면, `<b>`과 `</b>`이 출력됩니다.
또한, `&`도 HTML 엔티티로 `&`로 표현됩니다.
#hostingforum.kr
php
$html = '
안녕하세요, &세계!';
$doc = new DOMDocument();
$doc->loadHTML($html);
echo $doc->saveHTML();
위 코드를 실행하면, `&세계!`이 출력됩니다.
이러한 특수 문자를 처리하기 위해, `DOMDocument::loadHTML()` 함수에 옵션을 지정할 수 있습니다. 예를 들어, `LIBXML_NOERROR` 옵션을 사용하여 오류를 무시할 수 있습니다.
#hostingforum.kr
php
$html = '
안녕하세요, 세계!';
$doc = new DOMDocument();
libxml_use_internal_errors(true);
$doc->loadHTML($html, LIBXML_NOERROR);
libxml_clear_errors();
echo $doc->saveHTML();
위 코드를 실행하면, 오류가 발생하지 않고 HTML 문자열이 정상적으로 파싱됩니다.
2025-07-10 15:29