Zend_Gdata_Docs.xml 7.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 15156 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.gdata.docs">
  5. <title>Verwenden der Google Dokumente Listen Daten API</title>
  6. <para>
  7. Die Google Dokumente Listen Daten API erlaubt es Client Anwendungen Dokumente zu Google Dokumente
  8. hochzuladen und diese in der Form von Google Daten API ("GData") Feeds aufzulisten. Die Client
  9. Anwendung kann eine Liste von Benutzer Dokumenten anfragen, und den Inhalt in einem existierenden
  10. Dokument abfragen.
  11. </para>
  12. <para>
  13. Siehe
  14. <ulink url="http://code.google.com/apis/documents/overview.html">http://code.google.com/apis/documents/overview.html</ulink>
  15. für weitere Informationen über die Google Dokumente Listen API.
  16. </para>
  17. <sect2 id="zend.gdata.docs.listdocuments">
  18. <title>Eine Liste von Dokumenten erhalten</title>
  19. <para>
  20. Man kann eine Liste von den Google Dokumenten für einen bestimmten Benutzer erhalten indem die
  21. <code>getDocumentListFeed</code> Methode des Docs Services verwendet wird. Das Service gibt ein
  22. <classname>Zend_Gdata_Docs_DocumentListFeed</classname> Objekt zurück das eine Liste von dokumenten enthält
  23. die mit dem authentifizierten Benutzer assoziiert sind.
  24. </para>
  25. <programlisting role="php"><![CDATA[
  26. $service = Zend_Gdata_Docs::AUTH_SERVICE_NAME;
  27. $client = Zend_Gdata_ClientLogin::getHttpClient($user, $pass, $service);
  28. $docs = new Zend_Gdata_Docs($client);
  29. $feed = $docs->getDocumentListFeed();
  30. ]]></programlisting>
  31. <para>
  32. Das sich ergebende <classname>Zend_Gdata_Docs_DocumentListFeed</classname> Objekt repräsentiert die Antwort
  33. des Servers. Dieser Feed enthält eine Liste von <classname>Zend_Gdata_Docs_DocumentListEntry</classname>
  34. Objekten (<code>$feed->entries</code>), wobei jeder von Ihnen ein einzelnes Google Dokument
  35. repräsentiert.
  36. </para>
  37. </sect2>
  38. <sect2 id="zend.gdata.docs.creating">
  39. <title>Ein Dokument hochladen</title>
  40. <para>
  41. Man kann ein neues Google Dokument erstellen indem ein Wortverarbeitungs Dokument, eine
  42. Tabellenkalkulation oder eine Präsentation hochgeladen wird. Dieses Beispiel ist vom interaktiven
  43. Docs.php Beispiel welches mit der Bibliothek kommt. Es demonstriert das Hochladen einer Datei und
  44. das Ausdrucken der Information über das Ergebnis vom Server.
  45. </para>
  46. <programlisting role="php"><![CDATA[
  47. /**
  48. * Ein spezielles Dokument hochladen
  49. *
  50. * @param Zend_Gdata_Docs $docs Das Service Objekt das für die Kommunikation
  51. * mit dem Google Dokument Service verwendet wird
  52. * @param boolean $html True Wenn die Ausgabe für die Ausgabe in einem Web
  53. * Browser formatiert sein soll
  54. * @param string $originalFileName Der Name der Datei die hochgeladen werden
  55. * soll. Der MIME-Typ dieser Datei wird von der
  56. * Erweiterung des Dateinamens eruiert. Zum
  57. * Beispiel wird test.csv als Komma geteilter
  58. * Inhalt hochgeladen und in eine
  59. * Tabellenkalkulation konvertiert
  60. * @param string $temporaryFileLocation (Optional) Die Datei in der die Daten
  61. * für das Dokument gespeichert werden.
  62. * Das wird verwendet wenn die Datei von
  63. * der Maschine des Clients zum Server
  64. * hochgeladen und in einer temporären
  65. * Datei gespeichert wurde die keine
  66. * Erweiterung hat. Wenn dieser Parameter
  67. * null ist, wird die Datei von
  68. * originalFileName gelesen.
  69. */
  70. function uploadDocument($docs, $html, $originalFileName,
  71. $temporaryFileLocation) {
  72. $fileToUpload = $originalFileName;
  73. if ($temporaryFileLocation) {
  74. $fileToUpload = $temporaryFileLocation;
  75. }
  76. // Datei hochladen un in ein Google Dokument konvertieren Der originale
  77. // Dateiname wird als Titel des Dokuments verwendet und der MIME Typ wird
  78. // basieren auf der erweiterung des originalen Dateinamens eruiert.
  79. $newDocumentEntry = $docs->uploadFile($fileToUpload, $originalFileName,
  80. null, Zend_Gdata_Docs::DOCUMENTS_LIST_FEED_URI);
  81. echo "Neuer Titel des Dokuments: ";
  82. if ($html) {
  83. // Die URL der HTML Ansicht dieses Dokuments finden.
  84. $alternateLink = '';
  85. foreach ($newDocumentEntry->link as $link) {
  86. if ($link->getRel() === 'alternate') {
  87. $alternateLink = $link->getHref();
  88. }
  89. }
  90. // Den Titellink zum dokument auf docs.google.com erstellen.
  91. echo "<a href=\"$alternateLink\">\n";
  92. }
  93. echo $newDocumentEntry->title."\n";
  94. if ($html) {echo "</a>\n";}
  95. }
  96. ]]></programlisting>
  97. </sect2>
  98. <sect2 id="zend.gdata.docs.queries">
  99. <title>Den Dokumenten Feed durchsuchen</title>
  100. <para>
  101. Die Dokumenten Liste kann durchsucht werden indem einer der
  102. <ulink url="http://code.google.com/apis/gdata/reference.html#Queries">standardmäßigen
  103. Google Daten API Abfrageparameter</ulink> verwendet wird. Kategorien werden verwendet um den
  104. Typ des Dokuments das zurückgegeben wird (Wortverarbeitungs Dokument, Tabellenkalkulation)
  105. einzuschränken. Detailiertere Informationen über Parameter die speziell in der Dokumenten Liste
  106. vorhanden sind können in der
  107. <ulink url="http://code.google.com/apis/documents/reference.html#Parameters">Dokumenten Listen Daten API Referenz Anleitung</ulink>
  108. gefunden werden.
  109. </para>
  110. <sect3 id="zend.gdata.docs.listwpdocuments">
  111. <title>Eine Liste von Wortverarbeitungs Dokumenten erhalten</title>
  112. <para>
  113. Ein Feed der alle Dokumente eines speziellen Typs enthält kann auch angefragt werden.
  114. Um zum Beispiel eine Liste von eigenen Wortverarbeitungs Dokumenten zu sehen, würde man eine
  115. Kategorieanfrage wie folgt durchführen.
  116. </para>
  117. <programlisting role="php"><![CDATA[
  118. $feed = $docs->getDocumentListFeed(
  119. 'http://docs.google.com/feeds/documents/private/full/-/document');
  120. ]]></programlisting>
  121. </sect3>
  122. <sect3 id="zend.gdata.docs.listspreadsheets">
  123. <title>Eine Liste von Tabellenkalkulationen erhalten</title>
  124. <para>
  125. Um eine Liste aller eigenen Google Tabellenkalkulationen zu erhalten kann die folgende
  126. Abfrage verwendet werden:
  127. </para>
  128. <programlisting role="php"><![CDATA[
  129. $feed = $docs->getDocumentListFeed(
  130. 'http://docs.google.com/feeds/documents/private/full/-/spreadsheet');
  131. ]]></programlisting>
  132. </sect3>
  133. <sect3 id="zend.gdata.docs.textquery">
  134. <title>Eine Textabfrage durchführen</title>
  135. <para>
  136. Der Inhalt von Dokumenten kann durch Verwendung von <classname>Zend_Gdata_Docs_Query</classname> in der
  137. Abfrage durchsucht werden. Ein Abfrage Objekt kann verwendet werden um eine Abfrage URI zu
  138. erstellen, wobei der Suchbegriff als Parameter übergeben wird. Hier ist eine Beispielmethode
  139. welche die Dokumenten Liste nach Dokumenten abfrage die den Suchstring enthalten:
  140. </para>
  141. <programlisting role="php"><![CDATA[
  142. $docsQuery = new Zend_Gdata_Docs_Query();
  143. $docsQuery->setQuery($query);
  144. $feed = $client->getDocumentListFeed($docsQuery);
  145. ]]></programlisting>
  146. </sect3>
  147. </sect2>
  148. </sect1>