PHP - Función xmlwriter_start_dtd ()

Definición y uso

XML es un lenguaje de marcado para compartir los datos a través de la web, XML es legible tanto para humanos como para máquinas. La extensión XMLWriter tiene internamente la API libxml xmlWriter y se usa para escribir / crear el contenido de un documento XML. Los documentos XML generados por esto no se almacenan en caché y solo se reenvían.

los xmlwriter_start_dtd() La función se utiliza para crear un inicio de la etiqueta DTD.

Sintaxis

xmlwriter_start_dtd($writer, $name, $public_id, $system_id);

Parámetros

No Señor Descripción de parámetros
1

writer(Mandatory)

Este es un objeto de la clase XMLWriter que representa el documento XML que desea modificar / crear.

2

name(Mandatory)

Este es un valor de cadena que representa el nombre calificado del tipo de documento.

3

public_id(Optional)

Este es un valor de cadena que representa el nombre calificado del tipo de documento.

4

system_id(Optional)

Este es un valor de cadena que representa el nombre calificado del tipo de documento.

Valores devueltos

Esta función devuelve un valor booleano que es VERDADERO en caso de éxito y FALSO en caso de falla.

Versión PHP

Esta función se introdujo por primera vez en PHP Versión 5 y funciona en todas las versiones posteriores.

Ejemplo

El siguiente ejemplo demuestra el uso de xmlwriter_start_dtd() función -

<?php
   //Opening a writer
   $uri = "result.xml";
   $writer = xmlwriter_open_uri($uri);

   //Starting the document
   xmlwriter_start_document($writer);

   //Starting the Dtd tag
   xmlwriter_start_dtd($writer, 'test_dtd', 'pub_1001', 'sys_1001');

   //Ending the Dtd tag
   xmlwriter_end_dtd($writer); 
   xmlwriter_set_indent($writer, TRUE);
   xmlwriter_set_indent_string($writer, "    ");

   //Starting an element
   xmlwriter_start_element($writer, 'Tutorial');

   //Starting a element tag
   xmlwriter_start_element($writer, 'name');

   //Adding text to the element
   xmlwriter_text($writer, 'JavaFX');  
   xmlwriter_end_element($writer);
   xmlwriter_start_element($writer, 'Author');
   
   //Adding text to the element
   xmlwriter_text($writer, 'Krishna');  
   xmlwriter_end_element($writer);

   //Ending the element
   xmlwriter_end_element($writer);

   //Ending the document
   xmlwriter_end_document($writer);
?>

Esto generará el siguiente documento XML:

<?xml version="1.0"?>
<!DOCTYPE test_dtd PUBLIC "pub_1001" "sys_1001"><Tutorial>
   <name>JavaFX</name>
   <Author>Krishna</Author>
</Tutorial>

Ejemplo

A continuación se muestra el ejemplo de esta función en estilo orientado a objetos:

<?php
   //Creating an XMLWriter
   $writer = new XMLWriter();

   //Opening a writer
   $uri = "result.xml";
   $writer->openUri($uri);

   //Starting the document
   $writer->startDocument();

   //Setting the indentation on
   $writer->setIndent(TRUE);
   
   //Setting the indentation
   $writer->setIndentString("    ");

   //Starting the Dtd tag
   $writer->startDtd('test_dtd', 'pub_1001', 'sys_1001');

   //Ending the Dtd tag
   $writer->endDtd(); 

   //Starting an element
   $writer->startElement('Tutorial');
   $writer->startElement('name');
   
   //Adding text to the element
   $writer->text('JavaFX');  
   $writer->endElement();
   $writer->startElement('Author');
   
   //Adding text to the element
   $writer->text('Krishna');  
   $writer->endElement();

   //Ending the element
   $writer->endElement();
   
   //Ending the document
   $writer->endDocument();
?>

Esto generará el siguiente documento XML:

<?xml version="1.0"?>
<!DOCTYPE test_dtd PUBLIC "pub_1001" "sys_1001">
<Tutorial>
   <name>JavaFX</name>
   <Author>Krishna</Author>
</Tutorial>