Zend_Pdf-Properties.xml 9.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 24249 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.pdf.info">
  5. <!-- @todo review and revise upon completion of refactoring -->
  6. <title>Dokument Informationen und Metadaten</title>
  7. <para>
  8. Ein <acronym>PDF</acronym> Dokument kann generelle Informationen wie den Titel, Author, und
  9. Erstellungs- sowie Modifikationsdatum enthalten.
  10. </para>
  11. <para>
  12. Historisch wird diese Information durch das Verwenden einer speziellen Info Struktur
  13. gespeichert. Diese struktur kann als assoziatives Array mithilfe der öffentlichen
  14. <property>properties</property> Eigenschaft des <classname>Zend_Pdf</classname> Objektes
  15. gelesen und geschrieben werden:
  16. </para>
  17. <programlisting language="php"><![CDATA[
  18. $pdf = Zend_Pdf::load($pdfPath);
  19. echo $pdf->properties['Title'] . "\n";
  20. echo $pdf->properties['Author'] . "\n";
  21. $pdf->properties['Title'] = 'Neuer Titel.';
  22. $pdf->save($pdfPath);
  23. ]]></programlisting>
  24. <para>
  25. Die folgenden Schlüssel sind im <acronym>PDF</acronym> v1.4 (Acrobat 5) Standard definiert:
  26. <itemizedlist>
  27. <listitem>
  28. <para>
  29. <emphasis>Title</emphasis> - String, optional, der Titel des Dokuments.
  30. </para>
  31. </listitem>
  32. <listitem>
  33. <para>
  34. <emphasis>Author</emphasis> - String, optional, der Name der Person die das
  35. Dokument erstellt hat.
  36. </para>
  37. </listitem>
  38. <listitem>
  39. <para>
  40. <emphasis>Subject</emphasis> - String, optional, was das Dokument beschreibt.
  41. </para>
  42. </listitem>
  43. <listitem>
  44. <para>
  45. <emphasis>Keywords</emphasis> - String, optional, mit dem Dokument assoziierte
  46. Wörter.
  47. </para>
  48. </listitem>
  49. <listitem>
  50. <para>
  51. <emphasis>Creator</emphasis> - String, optional, wenn das Dokument von einem
  52. anderen Format zu <acronym>PDF</acronym> konvertiert wurde, der Name der
  53. Anwendung (zum Beispiel, Adobe FrameMaker®) die das originale Dokument erstellt
  54. hat von dem es konvertiert wurde.
  55. </para>
  56. </listitem>
  57. <listitem>
  58. <para>
  59. <emphasis>Producer</emphasis> - String, optional, wenn das Dokument von einem
  60. anderen Format zu <acronym>PDF</acronym> konvertiert wurde, der Name der
  61. Anwendung (zum Beispiel, Acrobat Distiller) die es zu <acronym>PDF</acronym>
  62. konvertiert hat.
  63. </para>
  64. </listitem>
  65. <listitem>
  66. <para>
  67. <emphasis>CreationDate</emphasis> - Wtring, optional, Datum und Zeit der
  68. Erstellung des Dokumentes in der folgenden Form "D:YYYYMMDDHHmmSSOHH'mm'" wobei:
  69. <itemizedlist>
  70. <listitem><para><emphasis>YYYY</emphasis> ist das Jahr.</para></listitem>
  71. <listitem><para><emphasis>MM</emphasis> ist der Monat.</para></listitem>
  72. <listitem>
  73. <para><emphasis>DD</emphasis> ist der Tag (01–31).</para>
  74. </listitem>
  75. <listitem>
  76. <para><emphasis>HH</emphasis> ist die Stunde (00–23).</para>
  77. </listitem>
  78. <listitem>
  79. <para><emphasis>mm</emphasis>ist die Minute (00–59).</para>
  80. </listitem>
  81. <listitem>
  82. <para><emphasis>SS</emphasis> ist die Sekunde (00–59).</para>
  83. </listitem>
  84. <listitem>
  85. <para>
  86. <emphasis>O</emphasis> ist die Relation der lokalen Zeit zur
  87. Univeral Zeit (UT), vorangestellt von einem der folgenden Zeichen +,
  88. -, oder Z (siehe anbei).
  89. </para>
  90. </listitem>
  91. <listitem>
  92. <para>
  93. <emphasis>HH</emphasis> gefolgt von ' ist der absolute Wert des
  94. Offsets von UT in Stunden (00–23).
  95. </para>
  96. </listitem>
  97. <listitem>
  98. <para>
  99. <emphasis>mm</emphasis> gefolgt von ' ist der absolute Wert des
  100. Offsets von UT in Minuten (00–59).
  101. </para>
  102. </listitem>
  103. </itemizedlist>
  104. Das Apostroph Zeichen (') nach HH und mm ist Teil der Syntax. Alle Felder nach
  105. dem Jahr sind optional. (Die Prefix D:, obwohl auch optional, wird dringend
  106. empfohlen.) Der Standardwert für MM und DD sind beide 01; alle anderen
  107. numerischen Felder sind standardmäßig 0. Ein Pluszeichen (+) als Wert des O
  108. Feldes bedeutet das die lokale Zeit später als UT ist, ein Minuszeiche das die
  109. lokale Zeit früher als UT ist, und das Zeichen Z das die lokale Zeit identisch
  110. mit UT ist. Wenn keine UT Information spezifiziert ist, wird die Relation der
  111. spezifizierten Zeit zu UT als unbekannt angenommen. Egal ob die Zeitzone bekannt
  112. ist oder nicht, sollte der Rest des Datums in lokaler Zeit spezifiziert werden.
  113. </para>
  114. <para>
  115. Zum Beispiel, 23. Dezember, 1998, um 19:52, U.S. Pazifik Standard Zeit, wird
  116. dargestellt durch den String "D:199812231952−08'00'".
  117. </para>
  118. </listitem>
  119. <listitem>
  120. <para>
  121. <emphasis>ModDate</emphasis> - String, optional, das Datum und die Uhrzeit an
  122. dem das Dokument zuletzt geändert wurde, im selben Format wie
  123. <emphasis>CreationDate</emphasis>.
  124. </para>
  125. </listitem>
  126. <listitem>
  127. <para>
  128. <emphasis>Trapped</emphasis> - bool, optional, zeigt ob das Dokument modifiziert
  129. wurde um eingeschlossene Informationen zu enthalten.
  130. <itemizedlist>
  131. <listitem>
  132. <para>
  133. <emphasis><constant>TRUE</constant></emphasis> - Das Dokument wurde
  134. vollständig eingeschlossen; weiteres einschließen ist nicht
  135. notwendig.
  136. </para>
  137. </listitem>
  138. <listitem>
  139. <para>
  140. <emphasis><constant>FALSE</constant></emphasis> - Das Dokument wurde
  141. bisher noch nicht eingeschlossen, wenn das Einschließen gewümscht
  142. wird muß es noch getan werden.
  143. </para>
  144. </listitem>
  145. <listitem>
  146. <para>
  147. <emphasis><constant>NULL</constant></emphasis> - Entweder ist nicht
  148. bekannt ob das Dokument eingeschlossen wurde, oder es wurde bisher
  149. erst teilweise aber noch nicht vollständig eingeschlosssen; etwas
  150. zusätzliches Einschließen ist trotzdem noch notwendig.
  151. </para>
  152. </listitem>
  153. </itemizedlist>
  154. </para>
  155. </listitem>
  156. </itemizedlist>
  157. </para>
  158. <para>
  159. Seit <acronym>PDF</acronym> v 1.6 können Metadaten in einem speziellen
  160. <acronym>XML</acronym> Dokument gespeichert werden das dem <acronym>PDF</acronym> angehängt
  161. wird (XMP - <ulink
  162. url="http://www.adobe.com/products/xmp/">Extensible Metadata Platform</ulink>).
  163. </para>
  164. <para>
  165. Dieses <acronym>XML</acronym> Dokument kann empfangen und dem PDF mit der
  166. <methodname>Zend_Pdf::getMetadata()</methodname> und der
  167. <methodname>Zend_Pdf::setMetadata($metadata)</methodname> Methode wieder hinzugefügt werden:
  168. </para>
  169. <programlisting language="php"><![CDATA[
  170. $pdf = Zend_Pdf::load($pdfPath);
  171. $metadata = $pdf->getMetadata();
  172. $metadataDOM = new DOMDocument();
  173. $metadataDOM->loadXML($metadata);
  174. $xpath = new DOMXPath($metadataDOM);
  175. $pdfPreffixNamespaceURI = $xpath->query('/rdf:RDF/rdf:Description')
  176. ->item(0)
  177. ->lookupNamespaceURI('pdf');
  178. $xpath->registerNamespace('pdf', $pdfPreffixNamespaceURI);
  179. $titleNode = $xpath->query('/rdf:RDF/rdf:Description/pdf:Title')->item(0);
  180. $title = $titleNode->nodeValue;
  181. ...
  182. $titleNode->nodeValue = 'New title';
  183. $pdf->setMetadata($metadataDOM->saveXML());
  184. $pdf->save($pdfPath);
  185. ]]></programlisting>
  186. <para>
  187. Übliche Eingenschaften von Dokumenten werden verdoppelt un din der Info Struktur und dem
  188. Metadaten Dokument (wenn vorhanden) gespeichert. Die anwendung des Benutzer ist dafür
  189. verantwortlich das beide Synchron gehalten werden.
  190. </para>
  191. </sect1>