내장된 Expat 구문 분석기를 사용하면 PHP에서 XML 문서를 처리할 수 있습니다.
XML이란 무엇인가요?
XML은 데이터를 설명하는 데 사용되며 XML의 초점은 데이터입니다. XML 파일은 데이터의 구조를 설명합니다.
XML에는 미리 정의된 태그가 없습니다. 자신만의 태그를 정의해야 합니다.
Expat이란 무엇인가요?
XML 문서를 읽고 업데이트(생성 및 처리)하려면 XML 파서가 필요합니다.
XML 파서에는 두 가지 기본 유형이 있습니다.
·트리 기반 파서: 이 파서는 XML 문서를 트리 구조로 변환합니다. 전체 문서를 분석하고 DOM(문서 개체 모델)과 같은 트리 요소에 액세스할 수 있는 API를 제공합니다.
·이벤트 기반 파서: XML 문서를 일련의 이벤트로 처리합니다. 특정 이벤트가 발생하면 파서는 이를 처리하기 위해 함수를 호출합니다.
Expat 파서는 이벤트 기반 파서입니다.
이벤트 기반 파서는 결과가 아닌 XML 문서의 내용에 중점을 둡니다. 이 때문에 이벤트 기반 파서는 트리 기반 파서보다 더 빠르게 데이터에 액세스할 수 있습니다.
다음 XML 조각을 참조하세요.
<from>John</from>
이벤트 기반 파서는 위의 XML을 일련의 세 가지 이벤트로 보고합니다.
# 🎜 🎜#·시작 요소: from
·시작 CDATA 부분, 값: John
·# 🎜 🎜#Close 요소: from위의 XML 예에는 올바른 형식의 XML이 포함되어 있습니다. 그러나 이 예는 연관된 DTD(문서 유형 선언)가 없고 포함된 DTD도 없기 때문에 잘못된 XML입니다.
관련 권장사항: "
php 시작하기 튜토리얼"그러나 Expat 파서를 사용할 때는 아무런 차이가 없습니다. Expat은 유효성을 확인하지 않고 DTD를 무시하는 파서입니다.
이벤트 기반의 검증되지 않은 XML 파서인 Expat는 빠르고 가벼워서 PHP 웹 애플리케이션에 이상적입니다.
참고: XML 문서는 올바른 형식이어야 합니다. 그렇지 않으면 Expat에서 오류가 발생합니다.
InstallationXML Expat 파서는 PHP 코어의 필수 부분입니다. 이 기능을 사용하기 위해 설치가 필요하지 않습니다.
XML 파일이 예에서는 다음 XML 파일이 사용됩니다.
George <from>John</from>Reminder Don't forget the meeting!
#🎜🎜 # XML 파서 초기화
PHP에서 XML 파서를 초기화하고 다양한 XML 이벤트에 대한 핸들러를 정의한 다음 이 XML 파일을 구문 분석해야 합니다.
예:<?php //Initialize the XML parser $parser=xml_parser_create(); //Function to use at the start of an element function start($parser,$element_name,$element_attrs) { switch($element_name) { case "NOTE": echo "-- Note --<br />"; break; case "TO": echo "To: "; break; case "FROM": echo "From: "; break; case "HEADING": echo "Heading: "; break; case "BODY": echo "Message: "; } } //Function to use at the end of an element function stop($parser,$element_name) { echo "<br />"; } //Function to use when finding character data function char($parser,$data) { echo $data; } //Specify element handler xml_set_element_handler($parser,"start","stop"); //Specify data handler xml_set_character_data_handler($parser,"char"); //Open XML file $fp=fopen("test.xml","r"); //Read data while ($data=fread($fp,4096)) { xml_parse($parser,$data,feof($fp)) or die (sprintf("XML Error: %s at line %d", xml_error_string(xml_get_error_code($parser)), xml_get_current_line_number($parser))); } //Free the XML parser xml_parser_free($parser); ?>위 코드의 출력:
-- Note -- To: George From: John Heading: Reminder Message: Don't forget the meeting!작동 원리 설명: #🎜🎜 #·
xml_parser_create() 함수를 통해 XML 파서 초기화
·다른 이벤트 핸들러와 일치하는 함수 만들기
#🎜 🎜 #·xml_set_element_handler() 함수를 추가하여 파서가 시작 및 끝 태그를 발견할 때 실행할 함수를 정의합니다
·xml_set_character_data_handler() 추가 파서가 문자 데이터를 발견할 때 실행되는 함수
·xml_parse() 함수를 통해 "test.xml" 파일을 구문 분석# 🎜🎜 #
·오류가 있는 경우 xml_error_string() 함수를 추가하여 XML 오류를 텍스트 설명으로 변환
·#🎜🎜 #xml_parser_free() 함수 호출 xml_parser_create() 함수에 할당된 메모리를 해제하려면위 내용은 PHP 파서 란 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!