PHP XML 국외 거주자 파서

PHP XML Expat 파서


내장된 Expat 파서는 PHP에서 XML 문서를 처리할 수 있게 해줍니다.


XML이란 무엇인가요?

XML은 데이터가 무엇인지에 초점을 맞춰 데이터를 설명하는 데 사용됩니다. XML 파일은 데이터의 구조를 설명합니다.

XML에는 미리 정의된 태그가 없습니다. 자신만의 태그를 정의해야 합니다.

XML에 대해 자세히 알아보려면 XML 튜토리얼을 방문하세요.


Expat란 무엇인가요?

XML 문서를 읽고 업데이트(생성 및 처리)하려면 XML 파서가 필요합니다.

XML 파서에는 두 가지 기본 유형이 있습니다.

· 트리 기반 파서: 이 파서는 XML 문서를 트리 구조로 변환합니다. 전체 문서를 분석하고 DOM(문서 개체 모델)과 같은 트리의 요소에 대한 액세스를 제공합니다.

· 이벤트 기반 파서: XML 문서를 일련의 이벤트로 처리합니다. 특정 이벤트가 발생하면 파서는 이를 처리하는 함수를 호출합니다.

Expat 파서는 이벤트 기반 파서입니다.

이벤트 기반 파서는 구조보다는 XML 문서의 내용에 중점을 둡니다. 이 때문에 이벤트 기반 파서는 트리 기반 파서보다 더 빠르게 데이터에 액세스할 수 있습니다.

다음 XML 조각을 살펴보세요.

<from>Jani</from>

이벤트 기반 파서는 위 XML을 일련의 세 가지 이벤트로 보고합니다.

· 시작 요소: from

· 시작 CDATA 섹션, 값: Jani

· 닫는 요소: from

위의 XML 예에는 Good 형식이 포함되어 있습니다. XML. 그러나 이 인스턴스는 연결된 DTD(문서 유형 선언)가 없기 때문에 잘못된 XML입니다.

그러나 Expat 파서를 사용할 때는 아무런 차이가 없습니다. Expat은 유효성을 확인하지 않고 DTD를 무시하는 파서입니다.

이벤트 기반의 검증되지 않은 XML 파서인 Expat는 빠르고 가벼워서 PHP 웹 애플리케이션에 이상적입니다.

참고: XML 문서는 올바른 형식이어야 합니다. 그렇지 않으면 Expat에서 오류가 발생합니다.


설치

XML Expat 파서 기능은 PHP 코어의 필수 부분입니다. 이 기능을 사용하기 위해 설치가 필요하지 않습니다.


XML 파일

이 예에서는 다음 XML 파일이 사용됩니다:

<?xml version="1.0" encoding="ISO-8859-1"?>
 <note>
 <to>Tove</to>
 <from>Jani</from>
 <heading>Reminder</heading>
 <body>Don't forget me this weekend!</body>
 </note>


XML 파서 초기화

PHP에서 XML 파서를 초기화하고 다양한 XML 이벤트에 대한 핸들러를 정의한 다음 이 XML 파일을 파싱하겠습니다.

Instance

<?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);
 ?>

위 코드는 다음을 출력합니다:

-- 참고 --
받는 사람: Tove
보낸 사람: Jani
제목: 알림
메시지: 이번 주말에도 저를 잊지 마세요!

작동 원리:

1. xml_parser_create() 함수를 통해 XML 파서를 초기화합니다.

2. 다양한 이벤트 핸들러 기능

3.                                                             -                   -                          -                                     -                                   사용 중      사용 사용 사용   사용 사용 -                 xml_set_element 추가 _handler() 함수는 파서가 시작 태그와 끝 태그를 만났을 때 어떤 함수가 실행되는지 정의하기 위해 추가되었습니다. 문자 데이터가 발견되면 실행

5. xml_parse() 함수를 사용하여 "test.xml" 파일을 구문 분석합니다

6. 오류가 있는 경우 xml_error_string() 함수를 추가합니다. XML 오류를 텍스트 설명으로 변환합니다

7. xml_parser_free() 함수를 호출하여 xml_parser_create() 함수에 할당된 메모리를 해제합니다

PHP XML 소개 파서 XML 함수를 사용하면 XML 문서를 구문 분석할 수 있지만 유효성을 검사할 수는 없습니다.

XML은 표준 구조 문서 교환에 사용되는 데이터 형식입니다. php.cn에서 XML에 대한 자세한 정보를 찾을 수 있습니다.

이 확장 프로그램은 Expat XML 파서를 사용합니다.

Expat는 XML 문서를 일련의 이벤트로 처리하는 이벤트 기반 파서입니다. 이벤트가 발생하면 지정된 함수를 호출하여 이를 처리합니다.

Expat는 문서에 연결된 모든 DTD를 무시하는 검증 없는 파서입니다. 그러나 문서의 형식이 좋지 않으면 오류 메시지가 표시됩니다.

Expat는 이벤트 기반의 검증이 필요 없는 파서이기 때문에 빠르고 웹 애플리케이션에 적합합니다.

XML 파서 기능을 사용하면 XML 파서를 생성하고 XML 이벤트에 대한 핸들러를 정의할 수 있습니다.


설치

XML Parser 기능은 PHP 코어의 필수 부분입니다. 이 기능을 사용하기 위해 설치가 필요하지 않습니다.

PHP XML 파서 기능

PHP: 이 기능을 지원하는 가장 초기의 PHP 버전을 나타냅니다.


QQ截图20161009165838.pngPHP XML 파서 상수

QQ截图20161009165856.png

QQ截图20161009165909.png

지속적인 학습
||
<?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); ?>
  • 코스 추천
  • 코스웨어 다운로드
현재 코스웨어를 다운로드할 수 없습니다. 현재 직원들이 정리하고 있습니다. 앞으로도 본 강좌에 많은 관심 부탁드립니다~