Zend_File_Transfer-Introduction.xml 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 15156 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.file.transfer.introduction">
  5. <title>Zend_File_Transfer</title>
  6. <para>
  7. <classname>Zend_File_Transfer</classname> bietet exzessiven Support für Datei Uploads und Downloads. Es kommt
  8. mit eingebauten Prüfungen für Dateien und Funktionslitäten um Dateien mit Filtern zu verändern.
  9. Protokoll-Adapter erlauben <classname>Zend_File_Transfer</classname> die selbe API für Transportprotokolle wie
  10. HTTP, FTP, WEBDAV und andere zu verwenden.
  11. </para>
  12. <note>
  13. <title>Einschränkungen</title>
  14. <para>
  15. Die aktuelle Implementation von <classname>Zend_File_Transfer</classname>
  16. ist auf HTTP Post Uploads limitiert. Andere Adapter die Downloads und andere Protokolle
  17. unterstützen werden in zukünftigen Releases hinzugefügt. Aktuell sollte
  18. <classname>Zend_File_Transfer_Adapter_Http</classname> direkt verwendet werden. Sobald andere Adapter
  19. vorhanden sind, kann ein gemeinsames Interface verwendet werden.
  20. </para>
  21. </note>
  22. <note>
  23. <title>Formulare</title>
  24. <para>
  25. Wenn man <classname>Zend_Form</classname> verwendet sollte man die APIs die von <classname>Zend_Form</classname> zur
  26. Verfügung gestellt werden, und <classname>Zend_File_Transfer</classname> nicht direkt, verwenden. Der
  27. Dateitransfer Support von <classname>Zend_Form</classname> ist in <classname>Zend_File_Transfer</classname>
  28. implementiert, weshalb die Informationen in diesem Kapitel für fortgeschrittene Benutzer von
  29. <classname>Zend_Form</classname> interessant sind.
  30. </para>
  31. </note>
  32. <para>
  33. Die Verwendung von <classname>Zend_File_Transfer</classname> ist relativ einfach. Es besteht aus zwei Teilen.
  34. Dem HTTP Formular, wärend <classname>Zend_File_Transfer</classname> die hochgeladenen Dateien behandelt.
  35. Siehe das folgende Beispiel:
  36. </para>
  37. <example id="zend.file.transfer.introduction.example">
  38. <title>Einfaches Formular für File-Uploads</title>
  39. <para>
  40. Dieses Beispiel zeigt einen einfachen Dateiupload. Das erste Teil ist das Dateiformular.
  41. In unserem Beispiel gibt es nur eine Datei welche wir hochladen wollen.
  42. </para>
  43. <programlisting><![CDATA[
  44. <form enctype="multipart/form-data" action="/file/upload" method="POST">
  45. <input type="hidden" name="MAX_FILE_SIZE" value="100000" />
  46. Choose a file to upload: <input name="uploadedfile" type="file" />
  47. <br />
  48. <input type="submit" value="Upload File" />
  49. </form>
  50. ]]></programlisting>
  51. <para>
  52. Der Bequemlichkeit halber kann
  53. <link linkend="zend.form.standardElements.file">Zend_Form_Element_File</link> verwendet werden
  54. statt das HTML manuell zu erstellen.
  55. </para>
  56. <para>
  57. Der nächste Schritt ist die Erstellung des Empfängers des Uploads. In unserem Beispiel ist der
  58. Empfänger bei <code>/file/upload</code> zu finden. Als nächstes erstellen wir also den
  59. <code>file</code> Controller mit der <code>upload</code> Aktion.
  60. </para>
  61. <programlisting role="php"><![CDATA[
  62. $adapter = new Zend_File_Transfer_Adapter_Http();
  63. $adapter->setDestination('C:\temp');
  64. if (!$adapter->receive()) {
  65. $messages = $adapter->getMessages();
  66. echo implode("\n", $messages);
  67. }
  68. ]]></programlisting>
  69. <para>
  70. Dieses Codebeispiel demonstriert die einfachste Verwendung von <classname>Zend_File_Transfer</classname>.
  71. Ein lokales Ziel wird mit der <code>setDestination</code> Methode definiert, und anschließend die
  72. <code>receive()</code> Methode aufgerufen. Wenn irgendwelche Uploadfehler auftreten werden diese
  73. als Ausnahme zurückgegeben.
  74. </para>
  75. </example>
  76. <note>
  77. <title>Achtung</title>
  78. <para>
  79. Dieses Beispiel ist nur für die Demonstration der grundsätzlichen API von
  80. <classname>Zend_File_Transfer</classname>. Man sollte dieses Code Beispiel
  81. <emphasis role="strong">niemals</emphasis> in einer Produktivumgebung einsetzen da es
  82. massive Sicherheitslücken aufweisst. Man sollte immer Prüfungen verwenden um die Sicherheit
  83. zu erhöhen.
  84. </para>
  85. </note>
  86. <sect2 id="zend.file.transfer.introduction.adapters">
  87. <title>Von Zend_File_Transfer unterstützte Adapter</title>
  88. <para>
  89. <classname>Zend_File_Transfer</classname> wurde designt um verschiedenste Adapter und auch Richtungen zu
  90. unterstützen. Mit <classname>Zend_File_Transfer</classname> kann man Dateien Hochladen, Herunterladen und
  91. sogar Weiterleiten (Hochladen mit einem Adapter und Herunterladen mit einem anderen Adapter zur
  92. gleichen Zeit).
  93. </para>
  94. </sect2>
  95. <sect2 id="zend.file.transfer.introduction.options">
  96. <title>Optionen für Zend_File_Transfer</title>
  97. <para>
  98. <classname>Zend_File_Transfer</classname> und seine Adapter unterstützen verschiedene Optionen. Alle Optionen
  99. können gesetzt werden indem Sie entweder dem Constructor übergeben werden, oder durch Aufruf der
  100. <code>setOptions($options)</code>. <code>getOptions()</code> gibt die Optionen zurück die aktuell
  101. gesetzt sind. Nachfolgend ist eine Liste aller unterstützten Optionen:
  102. </para>
  103. <itemizedlist>
  104. <listitem>
  105. <para>
  106. <emphasis role="strong">ignoreNoFile</emphasis>: Wenn diese Option auf true gesetzt ist,
  107. ignorieren alle Prüfer Dateien die nicht vom Formular hochgeladen wurde. Der
  108. Standardwert ist false, was einen Fehler verursacht wenn die Datei nicht spezifiziert wurde.
  109. </para>
  110. </listitem>
  111. </itemizedlist>
  112. </sect2>
  113. <sect2 id="zend.file.transfer.introduction.checking">
  114. <title>Dateien prüfen</title>
  115. <para>
  116. <classname>Zend_File_Transfer</classname> hat verschiedene Methoden die auf verschiedenste Stati von
  117. spezifizierten Dateien prüfen. Diese sind nützlich wenn man Dateien bearbeiten will nachdem
  118. Sie empfangen wurden. Diese Methoden beinhalten:
  119. </para>
  120. <itemizedlist>
  121. <listitem>
  122. <para>
  123. <emphasis role="strong">isValid($files = null)</emphasis>: Diese Methode prüft ob die
  124. angegebene Datei gültig ist, basierend auf den Prüfungen welche dieser Datei
  125. angehängt sind. Wenn keine Dateien spezifiziert wurden, werden alle Dateien geprüft.
  126. Man kann <code>isValid()</code> aufrufen bevor <code>receive()</code> aufgerufen wird;
  127. in diesem Fall ruft <code>receive()</code> intern <code>isValid()</code> nicht mehr auf.
  128. </para>
  129. </listitem>
  130. <listitem>
  131. <para>
  132. <emphasis role="strong">isUploaded($files = null)</emphasis>: Diese Methode prüft ob die
  133. spezifizierte Datei vom Benutzer hochgeladen wurde. Das ist nützlich wenn man eine oder
  134. mehrere Dateien definiert hat. Wenn keine Dateien spezifiziert wurden, werden alle
  135. Dateien geprüft.
  136. </para>
  137. </listitem>
  138. <listitem>
  139. <para>
  140. <emphasis role="strong">isReceived($files = null)</emphasis>: Diese Methode prüft ob die
  141. spezifizierte Datei bereits empfangen wurde. Wenn keine Dateien angegeben wurden, werden
  142. alle Dateien geprüft.
  143. </para>
  144. </listitem>
  145. </itemizedlist>
  146. <example id="zend.file.transfer.introduction.checking.example">
  147. <title>Dateien prüfen</title>
  148. <programlisting role="php"><![CDATA[
  149. $upload = new Zend_File_Transfer();
  150. // Gibt alle bekannten internen Datei Informationen zurück
  151. $files = $upload->getFileInfo();
  152. foreach ($files as $file => $info) {
  153. // Datei hochgeladen ?
  154. if (!$upload->isUploaded($file)) {
  155. print "Warum hast Du die Datei nicht hochgeladen ?";
  156. continue;
  157. }
  158. // Prüfungen sind ok ?
  159. if (!$upload->isValid($file)) {
  160. print "Sorry, aber die Datei ist nicht das was wir wollten";
  161. continue;
  162. }
  163. }
  164. $upload->receive();
  165. ]]></programlisting>
  166. </example>
  167. </sect2>
  168. <sect2 id="zend.file.transfer.introduction.informations">
  169. <title>Zusätzliche Dateiinformationen</title>
  170. <para>
  171. <classname>Zend_File_Transfer</classname> kann zusätzliche Informationen über Dateien zurückgeben.
  172. Die folgenden Methoden sind vorhanden:
  173. </para>
  174. <itemizedlist>
  175. <listitem>
  176. <para>
  177. <emphasis role="strong">getFileName($file = null, $path = true)</emphasis>: Diese Methode
  178. gibt den wirklichen Namen der übertragenen Datei zurück.
  179. </para>
  180. </listitem>
  181. <listitem>
  182. <para>
  183. <emphasis role="strong">getFileInfo($file = null)</emphasis>: Diese Methode gibt die
  184. internen Informationen für die angegebene übertragene Datei zurück.
  185. </para>
  186. </listitem>
  187. <listitem>
  188. <para>
  189. <emphasis role="strong">getFileSize($file = null)</emphasis>: Diese Methode gibt die
  190. echte Dateigröße für die angegebene Datei zurück.
  191. </para>
  192. </listitem>
  193. <listitem>
  194. <para>
  195. <emphasis role="strong">getHash($hash = 'crc32', $files = null)</emphasis>: Diese Methode
  196. gibt einen Hash des Inhalts einer angegebenen übertragenen Datei zurück.
  197. </para>
  198. </listitem>
  199. <listitem>
  200. <para>
  201. <emphasis role="strong">getMimeType($files = null)</emphasis>: Diese Methode gibt den
  202. Mimetyp der angegebenen übertragenen Datei zurück.
  203. </para>
  204. </listitem>
  205. </itemizedlist>
  206. <para>
  207. <code>getFileName()</code> akzeptiert den Namen des Elements als ersten Parameter. Wenn kein Name
  208. angegeben wird, werden alle bekannten Dateinamen in einem Array zurückgegeben. Wenn die Datei
  209. eine MultiDatei ist, wird auch ein Array zurückgegeben. Wenn nur eine einzelne Datei vorhanden ist
  210. wird nur ein String zurückgegeben.
  211. </para>
  212. <para>
  213. Standardmäßig werden Dateinamen mit dem kompletten Pfad zurückgegeben. Wenn man nur den Dateinamen
  214. ohne Pfad benötigt, kann der zweite Parameter <code>$path</code> gesetzt werden, welcher den
  215. Dateinamen ausschneidet wenn er auf false gesetzt wird.
  216. </para>
  217. <example id="zend.file.transfer.introduction.informations.example1">
  218. <title>Den Dateinamen bekommen</title>
  219. <programlisting role="php"><![CDATA[
  220. $upload = new Zend_File_Transfer();
  221. $upload->receive();
  222. // Gibt die Dateinamen aller Dateien zurück
  223. $names = $upload->getFileName();
  224. // Gibt den Dateinamen des Formularelements 'foo' zurück
  225. $names = $upload->getFileName('foo');
  226. ]]></programlisting>
  227. </example>
  228. <note>
  229. <para>
  230. Es ist zu beachten das sich der Dateinamen ändern kann nachdem die Datei empfangen wurde
  231. (receive) weil alle Filter angewendet werden, sobald die Datei empfangen wurde.
  232. Deswegen sollte man <code>getFileName()</code> immer ausführen nachdem die Dateien
  233. empfangen wurden.
  234. </para>
  235. </note>
  236. <para>
  237. <code>getFileSize()</code> gibt standardmäßig die echte Dateigröße in SI Schreibweise zurück
  238. was bedeutet das man <code>2kB</code> statt <code>2048</code> erhält. Wenn man die reine
  239. Größe benötigt muß man die <code>useByteString</code> Option auf false setzen.
  240. </para>
  241. <example id="zend.file.transfer.introduction.informations.example.getfilesize">
  242. <title>Die Größe einer Datei erhalten</title>
  243. <programlisting role="php"><![CDATA[
  244. $upload = new Zend_File_Transfer();
  245. $upload->receive();
  246. // Gibt die Größen aller Dateien als Array zurück
  247. // wenn mehr als eine Datei hochgeladen wurde
  248. $size = $upload->getFileSize();
  249. // Wechsle die SI Schreibweise damit reine Nummern zurückgegeben werden
  250. $upload->setOption(array('useByteString' => false));
  251. $size = $upload->getFileSize();
  252. ]]></programlisting>
  253. </example>
  254. <para>
  255. <code>getHash()</code> akzeptiert den Namen eines Hash Algorithmus als ersten Parameter. Für eine
  256. Liste bekannter Algorithmen kann in
  257. <ulink url="http://php.net/hash_algos">PHP's hash_algos Methode</ulink> gesehen werden. Wenn kein
  258. Algorithmus spezifiziert wird, wird <code>crc32</code> als Standardalgorithmus verwendet.
  259. </para>
  260. <example id="zend.file.transfer.introduction.informations.example2">
  261. <title>Den Hash einer Datei erhalten</title>
  262. <programlisting role="php"><![CDATA[
  263. $upload = new Zend_File_Transfer();
  264. $upload->receive();
  265. // Gibt die Hashes von allen Dateien als Array zurück
  266. // wenn mehr als eine Datei hochgeladen wurde
  267. $hash = $upload->getHash('md5');
  268. // Gibt den Has für das 'foo' Formularelement zurück
  269. $names = $upload->getHash('crc32', 'foo');
  270. ]]></programlisting>
  271. </example>
  272. <note>
  273. <para>
  274. Es ist zu beachten das der zurückgegebene Wert ein Array ist, wenn die Datei oder der
  275. Formularname mehr als eine Datei enthält.
  276. </para>
  277. </note>
  278. <para>
  279. <code>getMimeType()</code> gibt den Mimetyp einer Datei zurück. Wenn mehr als eine Datei hochgeladen
  280. wurde wird ein Array zurückgegeben, andernfalls ein String.
  281. </para>
  282. <example id="zend.file.transfer.introduction.informations.getmimetype">
  283. <title>Den Mimetyp einer Datei bekommen</title>
  284. <programlisting role="php"><![CDATA[
  285. $upload = new Zend_File_Transfer();
  286. $upload->receive();
  287. $mime = $upload->getMimeType();
  288. // Gibt den Mimetyp des 'foo' Form Elements zurück
  289. $names = $upload->getMimeType('foo');
  290. ]]></programlisting>
  291. </example>
  292. <note>
  293. <para>
  294. Beachte das diese Methode die fileinfo Erweiterung verwendet wenn Sie vorhanden ist. Wenn diese
  295. Erweiterung nicht gefunden werden kann wird die mimemagic Erweiterung verwendet. Wenn keine
  296. Erweiterung gefunden wird, dann wird der Mimetyp verwendet der vom Dateiserver wärend des
  297. Hochladens der Datei angegeben wurde.
  298. </para>
  299. </note>
  300. </sect2>
  301. <sect2 id="zend.file.transfer.introduction.uploadprogress">
  302. <title>Fortschritt für Datei Uploads</title>
  303. <para>
  304. <classname>Zend_File_Transfer</classname> kann den aktuellen Status eines gerade stattfindenden Datei Uploads
  305. erheben. Um dieses Feature zu verwenden muß man entweder die <code>APC</code> Erweiterung
  306. verwenden, die mit den meisten standardmäßigen PHP Installationen vorhanden ist, oder die
  307. <code>uploadprogress</code> Erweiterung. Beide Erweiterungen werden erkannt und automatisch
  308. verwendet. Um den Fortschritt zu erhalten muß man einige Voraussetzungen erfüllen.
  309. </para>
  310. <para>
  311. Erstens, muß man entweder <code>APC</code> oder <code>uploadprogress</code> aktiviert haben.
  312. Es ist zu beachten das dieses Feature von <code>APC</code> in der eigenen php.ini ausgeschaltet
  313. werden kann.
  314. </para>
  315. <para>
  316. Zweitens, muß man die richtigen unsichtbaren Felder im Formular hinzugefügt haben das die Dateien
  317. sendet. Wenn man <classname>Zend_Form_Element_File</classname> verwendet werden diese unsichtbaren Felder
  318. automatisch von <classname>Zend_Form</classname> hinzugefügt.
  319. </para>
  320. <para>
  321. Wenn die oberen zwei Punkte vorhanden sind dann ist man in der Lage den aktuellen Fortschritt des
  322. Datei uploads zu erhalten indem man die <code>getProgress</code> Methode verwendet. Aktuell gibt
  323. es 2 offizielle Wege um das hand zu haben.
  324. </para>
  325. <sect3 id="zend.file.transfer.introduction.uploadprogress.progressadapter">
  326. <title>Verwenden eines Progressbar Adapters</title>
  327. <para>
  328. Man kann einen bequemen <emphasis>Zend_ProgressBar</emphasis> verwenden um den aktuellen
  329. Fortschritt zu erhalten und kann Ihn dann auf einfachem Wege dem Benutzer zeigen.
  330. </para>
  331. <para>
  332. Um das zu ermöglichen, muß man den gewünschten <emphasis>Zend_ProgressBar_Adapter</emphasis>
  333. bei <code>getProgress()</code> hinzufügen wenn es das erste Mal aufgerufen wird. Für Details
  334. über den zu verwendenden Adapter, bitte im Kapitel
  335. <link linkend="zend.progressbar.adapters">Zend_ProgressBar Standard Adapters</link> nachsehen.
  336. </para>
  337. <example id="zend.file.transfer.introduction.uploadprogress.progressadapter.example1">
  338. <title>Verwenden eines Progressbar Adapters um den aktuellen Status zu erhalten</title>
  339. <programlisting role="php"><![CDATA[
  340. $adapter = new Zend_ProgressBar_Adapter_Console();
  341. $upload = Zend_File_Transfer_Adapter_Http::getProgress($adapter);
  342. $upload = null;
  343. while (!$upload['done']) {
  344. $upload = Zend_File_Transfer_Adapter_Http:getProgress($upload);
  345. }
  346. ]]></programlisting>
  347. </example>
  348. <para>
  349. Die komplette Handhabung wird von <code>getProgress()</code> im Hintergrund durchgeführt.
  350. </para>
  351. </sect3>
  352. <sect3 id="zend.file.transfer.introduction.uploadprogress.manually">
  353. <title>getProgress() händisch verwenden</title>
  354. <para>
  355. Man kann mit <code>getProgress()</code> auch händisch arbeiten, also ohne ie Verwendung von
  356. <classname>Zend_ProgressBar</classname>.
  357. </para>
  358. <para>
  359. <code>getProgress()</code> muß ohne Einstellungen aufgerufen werden. Es gibt anschließend ein
  360. Array mit verschiedenen Schlüssel zurück. Sie unterscheiden sich, abhängig von der verwendeten
  361. PHP Extension. Aber die folgenden Schlüssel werden unabhängig von der Extension zurück gegeben:
  362. </para>
  363. <itemizedlist>
  364. <listitem>
  365. <para>
  366. <emphasis role="strong">id</emphasis>: Die ID dieses Uploads. Die ID identifiziert den
  367. Upload in der Extension. Sie wird automatisch geschrieben. Man sollte Sie nie ändern
  368. oder den Wert selbst setzen.
  369. </para>
  370. </listitem>
  371. <listitem>
  372. <para>
  373. <emphasis role="strong">total</emphasis>: Die komplette Größe der Datei die hochgeladen
  374. wird in Bytes als Integer.
  375. </para>
  376. </listitem>
  377. <listitem>
  378. <para>
  379. <emphasis role="strong">current</emphasis>: Die aktuelle hochgeladene Größe der
  380. Datei in Bytes als Integer.
  381. </para>
  382. </listitem>
  383. <listitem>
  384. <para>
  385. <emphasis role="strong">rate</emphasis>: Die durchschnittliche Geschwindigkeit des
  386. Uploads in Bytes pro Sekunde als Integer.
  387. </para>
  388. </listitem>
  389. <listitem>
  390. <para>
  391. <emphasis role="strong">done</emphasis>: Gibt true zurück wenn der Upload abgeschlossen
  392. wurde, andernfalls false.
  393. </para>
  394. </listitem>
  395. <listitem>
  396. <para>
  397. <emphasis role="strong">message</emphasis>: Die aktuelle Meldung. Entweder der
  398. Fortschritt als Text in der Form <emphasis role="strong">10kB / 200kB</emphasis>, oder
  399. eine hilfreiche Nachricht im Fall eines Problems. Probleme könnten sein, das kein
  400. Upload durchgeführt wird, das ein Fehler wärend des Empfangens der Daten, für den
  401. Fortschritt, aufgetreten ist, oder das der Upload abgebrochen wurde.
  402. </para>
  403. </listitem>
  404. <listitem>
  405. <para>
  406. <emphasis role="strong">progress</emphasis>: Dieser optionale Schlüssel nimmt eine
  407. Instanz von Zend_ProgressBar_Adapter oder Zend_ProgressBar, und erlaubt es, den aktuellen
  408. Status des Uploads, in einer Progressbar zu erhalten
  409. </para>
  410. </listitem>
  411. <listitem>
  412. <para>
  413. <emphasis role="strong">session</emphasis>: Dieser optionale Schlüssel nimmt den Namen
  414. eines Session Namespaces entgegen der in Zend_ProgressBar verwendet wird. Wenn dieser
  415. Schlüssel nicht angegeben wird, ist er standardmäßig
  416. <classname>Zend_File_Transfer_Adapter_Http_ProgressBar</classname>.
  417. </para>
  418. </listitem>
  419. </itemizedlist>
  420. <para>
  421. Alle anderen zurückgegebenen Schlüssel werden direkt von den Extensions übernommen und werden
  422. nicht geprüft.
  423. </para>
  424. <para>
  425. Das folgende Beispiel zeigt eine mögliche händische Verwendung:
  426. </para>
  427. <example id="zend.file.transfer.introduction.uploadprogress.manually.example1">
  428. <title>Händische Verwendung des Datei Fortschritts</title>
  429. <programlisting role="php"><![CDATA[
  430. $upload = Zend_File_Transfer_Adapter_Http::getProgress();
  431. while (!$upload['done']) {
  432. $upload = Zend_File_Transfer_Adapter_Http:getProgress($upload);
  433. print "\nAktueller Fortschritt:".$upload['message'];
  434. // Tu was zu tun ist
  435. }
  436. ]]></programlisting>
  437. </example>
  438. </sect3>
  439. </sect2>
  440. </sect1>
  441. <!--
  442. vim:se ts=4 sw=4 tw=80 et:
  443. -->