| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394 |
- <?xml version="1.0" encoding="UTF-8"?>
- <!-- EN-Revision: 24249 -->
- <!-- Reviewed: no -->
- <sect1 id="zend.mail.multiple-emails">
- <title>Versand von mehreren E-Mails über eine SMTP Verbindung</title>
- <para>
- Standardmäßig erstellt ein einzelner SMTP Transport eine einzelne Verbindung und verwendet
- sie wieder während der Laufzeit der Skriptausführung. Es können mehrere E-Mails über diese
- SMTP Verbindung gesendet werden. Ein RSET Kommando wird vor jeder Ausführung angewendet um
- sicherzustellen das der korrekte SMTP Handschlag folgt.
- </para>
- <para>
- Optional kann auch eine standardmäßige From Emailadresse und Name definiert werden sowie ein
- standardmäßiger reply-to Header. Das kann durch die statischen Methoden
- <methodname>setDefaultFrom()</methodname> und <methodname>setDefaultReplyTo()</methodname>
- getan werden. Diese Standardwerte werden verwendet wenn man keine From oder Reply-to Adresse
- oder -Name angibt bis die Standardwerte zurückgesetzt werden (gelöscht). Das Zurücksetzen
- der Standardwerte kann durch die Verwendung von <methodname>clearDefaultFrom()</methodname>
- und <methodname>clearDefaultReplyTo</methodname> durchgeführt werden.
- </para>
- <example id="zend.mail.multiple-emails.example-1">
- <title>Versand von mehreren E-Mails über eine SMTP Verbindung</title>
- <programlisting language="php"><![CDATA[
- // Transport erstellen
- $config = array('name' => 'sender.example.com');
- $transport = new Zend_Mail_Transport_Smtp('mail.example.com', $config);
- // Setzt From & Reply-To Adressen
- // und Namen für alle Emails die zu versenden sind
- Zend_Mail::setDefaultFrom('sender@example.com', 'John Doe');
- Zend_Mail::setDefaultReplyTo('replyto@example.com','Jane Doe');
- // Durch die Nachrichten gehen
- for ($i = 0; $i < 5; $i++) {
- $mail = new Zend_Mail();
- $mail->addTo('studio@example.com', 'Test');
- $mail->setFrom('studio@example.com', 'Test');
- $mail->setSubject(
- 'Demonstration - mit einer SMTP Verbindung mehrfache E-Mails senden'
- );
- $mail->setBodyText('...Hier die Nachricht...');
- $mail->send($transport);
- }
- // Setzt die Standardwerte zurück
- Zend_Mail::clearDefaultFrom();
- Zend_Mail::clearDefaultReplyTo();
- ]]></programlisting>
- </example>
- <para>
- Wenn man eine separate Verbindung für jeden Mailtransport haben will, muß der Transport vor
- und nach jedem Aufruf der <methodname>send()</methodname> Methode erstellt und gelöscht
- werden. Oder alternativ kann die Verbindung zwischen jedem Transport, durch Zugriff auf das
- Protokoll Objekt des Transportes, manipuliert werden.
- </para>
- <example id="zend.mail.multiple-emails.example-2">
- <title>Die Transportverbindung manuell kontrollieren</title>
- <programlisting language="php"><![CDATA[
- // Transport erstellen
- $transport = new Zend_Mail_Transport_Smtp();
- $protocol = new Zend_Mail_Protocol_Smtp('mail.example.com');
- $protocol->connect();
- $protocol->helo('mail.example.com');
- $transport->setConnection($protocol);
- // Durch die Nachrichten gehen
- for ($i = 0; $i < 5; $i++) {
- $mail = new Zend_Mail();
- $mail->addTo('studio@example.com', 'Test');
- $mail->setFrom('studio@example.com', 'Test');
- $mail->setSubject(
- 'Demonstration - mit einer SMTP Verbindung mehrfache E-Mails senden'
- );
- $mail->setBodyText('...Hier die Nachricht...');
- // Die Verbindung manuell kontrollieren
- $protocol->rset();
- $mail->send($transport);
- }
- $protocol->quit();
- $protocol->disconnect();
- ]]></programlisting>
- </example>
- </sect1>
|