class newsboy { var $xml_parser; var $xml_file; var $html; var $open_tag ; var $close_tag ;
//클래스 생성자
function newsboy() { $this->xml_parser = ""; $this->xml_file = ""; $this->html = ""; $this->open_tag = array(
//이것은 기본 설정이지만 수정이 매우 쉽습니다.
"NEWSBOY" => "nn", "STORY" => " ", "DATE " => "", "SLUG" => " ", "TEXT" => "", "PIC" => "", "NEWLINE" => "" ); $this->close_tag = array( "NEWSBOY" => "
nnn", "STORY" => "", "DATE" => "", "SLUG" => "
", "TEXT" => "n", "PIC" => " "
" ) }
//클래스 소멸자(PHP는 소멸자를 지원하지 않으므로 수동으로 호출해야 함)
function destroy() { xml_parser_free($this->xml_parser) }
//클래스 멤버
function concat($str) { $this->html .= $str; >function startElement($parser, $name, $attrs) { //global $open_tag; if ($format= $this->open_tag[$name]) { $this->html .= $format } }
function endElement($parser, $name) { global $close_tag; if ($format= $this->close_tag[$name]) { $this->html .= $format } }
function CharacterData($parser, $data) { $this->html .= $data }
/* function PIHandler($parser, $target, $data) { //스위치(strtolower($target)) { // 케이스 "php": eval($data); // break; //} }*/
function parse() { $this->xml_parser = xml_set_object($this-> xml_parser, &$this); // $map_array에서 태그를 찾을 수 있도록 대소문자 구분을 사용합니다.
xml_parser_set_option($this->xml_parser, XML_OPTION_CASE_FOLDING, true); xml_set_element_handler($this->xml_parser, "startElement", "endElement"); xml_set_character_data_handler($this->xml_parser, "characterData");//xml_set_processing_instruction_handler($this->xml_parser, "PIHandler");
if (!($fp = fopen($this->xml_file, "r"))) { die("XML 입력을 열 수 없습니다."); } while ($data = fread($fp, 4096)) { if (!xml_parse($this->xml_parser, $data, feof($fp))) { die(sprintf("XML 오류: %s at line %d", xml_error_string(xml_get_error_code($this->xml_parser)), xml_get_current_line_number($this->xml_parser))); } } }}
?>
------------------------- -----------------------------
재这个类的构造函数中,我创建了打开与关闭两个标记数组。数组的关键字与我后面将要分析的标记是
一样的,并且它们标记的值包含格式化打开与关闭标记的HTML代码. 용,
因为PHP不支持当一个对象释放时自动调用类的析构函数.
然后我倀然后我析打开 and 关闭标记主回调方法.数据分析方法, 将
사용于当打开和关闭标记中有数据时,对数据进行简单的格式化,后face我将向你演示如何将这些回调方法注册
到分析器中。
지금 startElement와 closeElement(当分析到一个打开或关闭标专时被分别调用)中使用 标记的name字
작성자 数组进行查询.值存가 ,则返回值并且追加到类的'html'의 인기를 끌고 있습니다后면.
'html'属性将지금은 以后我们真正显示文档内容적时候使사용.
문자데이터 방법 html属性后면。
被注释起来的叫PIHandler의 방법이 XML에 있습니다.
文档中处理php脚本。
이제 주요 구문 분석 메서드 호출을 설명하겠습니다. 구문 분석()!!!
첫 번째 줄은 xml_parser_create() 함수를 호출합니다. 이 함수는 expat xml 구문 분석기 인스턴스를 반환하고 다음 파일에 저장됩니다.
클래스의 속성&this->xml_parser.
다음으로 xml_set_object() 함수를 사용하여 클래스 메서드에 대한 콜백 함수를 등록해야 합니다.
저는 xml_set_object($this->xml_parser, &$this) 이렇게 사용합니다. 첫 번째 매개변수에는
을 사용하여 XML 파서를 보유하는 클래스 특성을 지정한 다음 두 번째 매개변수에는 PHP 개체의 인스턴스 주소를 지정했습니다. 이를 통해 분석기는 등록될 모든 콜백 함수가 해당 주소에 지정된 클래스의 실제 메서드임을 알 수 있습니다. 이는 C나 C++의 '참조에 의한 전달'과 같습니다.
어떤 사람들은 이를 단순히 '참조 변수'라고 부릅니다.
다음 줄에서는 대소문자
접기를 사용하여 xml_parser_set_option()을 호출하여 xml 파서 속성을 설정합니다. 대소문자 접기는 XML 문서를 구문 분석할 때 대소문자 구분을 신경 쓰지 않는다는 사실을 파서에게 알려줄 뿐입니다. 그러나
대소문자 구분을 사용하여 or 와 같은 두 개의 서로 다른 태그를 정의하려면 Set it 없이 수행할 수 있습니다. 위로.
xml_set_element_handler()를 사용하여
"startElement" 및 "endElement"라는 시작 태그와 끝 태그에 대한 콜백 함수를 지정합니다.
다음으로 xml_set_character_data_handler()를 사용하여
characterData()라는 콜백 함수로 문자 데이터 처리 핸들을 지정합니다. 주석이 달린 함수 호출인 xml_set_processing_instruction_handler(),
는 PIHandler() 함수를 등록하는 데 사용한 것입니다. PIHandler는 XML 문서에 포함되어 PHP 코드를 처리할 수 있습니다.
나머지 코드는 단순히 XML 파일을 읽고 구문 분석합니다. 오류가 발생하면
오류가 발생한 행 번호를 포함하여 오류 세부 정보가 반환됩니다.