미리 정의된 문자 "<"(보다 작음) 및 ">"(보다 큼)를 HTML 엔터티로 변환합니다.
<?php $str = " <b>굵은 </b> 텍스트입니다. " ; htmlspecialchars ( $str ) ? >위 코드의 HTML 출력은 다음과 같습니다(소스 코드 보기).
< ! HTML > <html> < body > 이것은 < b & gt; 굵은 글씨 입니다 . < / body > </html>위 코드의 브라우저 출력은 다음과 같습니다.
<b>굵은</b> 텍스트입니다.htmlspecialchars() 함수는 미리 정의된 일부 문자를 HTML 엔터티로 변환합니다.
사전 정의된 문자는 다음과 같습니다.
&(앰퍼샌드)는 &가 됩니다.
"(큰따옴표)는 "
'(작은따옴표)는 '
<(보다 작음)은 <가 됩니다.
> (보다 큼) >
팁: 특수 HTML 엔터티를 다시 문자로 변환하려면 htmlspecialchars_decode() 함수를 사용하세요.
htmlspecialchars( 문자열, 플래그, 문자 집합, double_encode )
매개변수 | 설명하다 |
---|---|
끈 | 필수의. 변환할 문자열을 지정합니다. |
깃발 | 선택 과목. 인용문 처리 방법, 잘못된 인코딩 및 사용할 문서 유형을 지정합니다. 사용 가능한 견적 유형: ENT_COMPAT - 기본값. 큰따옴표만 인코딩됩니다. ENT_QUOTES - 큰따옴표와 작은따옴표를 인코딩합니다. ENT_NOQUOTES - 따옴표를 인코딩하지 않습니다. 잘못된 인코딩: ENT_IGNORE - 함수가 빈 문자열을 반환하도록 하는 대신 잘못된 인코딩을 무시합니다. 이는 보안에 영향을 미칠 수 있으므로 피해야 합니다. ENT_SUBSTITUTE - 빈 문자열을 반환하는 대신 지정된 문자로 잘못된 인코딩을 유니코드 대체 문자 U+FFFD(UTF-8) 또는 &#FFFD;로 대체합니다. ENT_DISALLOWED - 지정된 문서 유형의 잘못된 코드 포인트를 유니코드 대체 문자 U+FFFD(UTF-8) 또는 &#FFFD;로 바꿉니다. 사용할 문서 유형을 지정하는 추가 플래그: ENT_HTML401 - 기본값. HTML 4.01로 처리된 코드. ENT_HTML5 - HTML 5로 처리된 코드입니다. ENT_XML1 - XML 1로 처리된 코드입니다. ENT_XHTML - XHTML 처리 코드입니다. |
문자 집합 | 선택 과목. 사용할 문자 집합을 지정하는 문자열입니다. 허용되는 값: UTF-8 - 기본값. ASCII 호환 멀티바이트 8비트 유니코드 ISO-8859-1 - 서유럽 ISO-8859-15 - 서유럽(유로 기호 추가 + ISO-8859-1에서 누락된 프랑스어 및 핀란드 문자) cp866 - DOS 관련 키릴 문자 집합 cp1251 - Windows 특정 키릴 문자 집합 cp1252 - Windows 특정 서유럽 문자 집합 KOI8-R - 러시아어 BIG5 - 주로 대만에서 사용되는 중국어 번체 GB2312 - 중국어 간체, 국가 표준 문자 집합 BIG5-HKSCS - 홍콩 확장이 가능한 Big5 Shift_JIS - 일본어 EUC-JP - 일본어 MacRoman - Mac 운영 체제에서 사용되는 문자 세트 참고: PHP 5.4 이전 버전에서는 인식할 수 없는 문자 집합이 무시되고 ISO-8859-1로 대체되었습니다. PHP 5.4부터 인식할 수 없는 문자 세트는 무시되고 UTF-8로 대체됩니다. |
double_encode | 선택 과목. 기존 HTML 엔터티를 인코딩할지 여부를 지정하는 부울 값입니다. 참 - 기본값. 각 엔터티가 변환됩니다. FALSE - 기존 HTML 엔터티가 인코딩되지 않습니다. |
반환 값: | 변환된 문자열을 반환합니다. 문자열 에 잘못된 인코딩이 포함된 경우 ENT_IGNORE 또는 ENT_SUBSTITUTE 플래그가 설정되지 않으면 빈 문자열이 반환됩니다. |
---|---|
PHP 버전: | 4+ |
업데이트 로그: | PHP 5에서는 문자 집합 매개변수의 기본값이 UTF-8로 변경되었습니다. PHP 5.4의 새로운 기능: ENT_SUBSTITUTE, ENT_DISALLOWED, ENT_HTML401, ENT_HTML5, ENT_XML1 및 ENT_XHTML. PHP 5.3에서는 ENT_IGNORE가 추가되었습니다. PHP 5.2.3에서는 double_encode 매개변수가 추가되었습니다. PHP 4.1에서는 문자 집합 매개 변수가 추가되었습니다. |
미리 정의된 일부 문자를 HTML 엔터티로 변환합니다.
<?php $ str = " 제인과 '타잔' " echo htmlspecialchars ( $str , ENT_COMPAT ) ; // 기본값, 큰따옴표만 인코딩됩니다. 에코 " <br> " ; htmlspecialchars ( $str , ENT_QUOTES ) ; // 큰따옴표와 작은따옴표를 인코딩합니다. 에코 " <br> " ; htmlspecialchars ( $str , ENT_NOQUOTES ) ; // 따옴표를 인코딩하지 않습니다. ?>위 코드의 HTML 출력은 다음과 같습니다(소스 코드 보기).
< ! HTML > <html> < body > 제인 & ' 타잔' < br > 제인 & '타잔' < br > 제인 & ' 타잔 ' </ body > </html>위 코드의 브라우저 출력은 다음과 같습니다.
제인 & '타잔'제인 & '타잔'제인 & '타잔'큰따옴표를 HTML 엔터티로 변환합니다.
<?php $str = ' 나는 "PHP"를 좋아합니다 . ' ; htmlspecialchars ( $str , ENT_QUOTES ) ; // 큰따옴표와 작은따옴표를 인코딩합니다. ?> ;위 코드의 HTML 출력은 다음과 같습니다(소스 코드 보기).
< ! HTML > <html> < body > 나는 " PHP " 를 좋아 합니다 . </html>위 코드의 브라우저 출력은 다음과 같습니다.
나는 "PHP"를 좋아합니다.