| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394 |
- <?xml version="1.0" encoding="UTF-8"?>
- <!-- EN-Revision: 24249 -->
- <!-- Reviewed: no -->
- <sect1 id="zend.mail.multiple-emails">
- <title>Envoyer plusieurs courriels par connexion SMTP</title>
- <para>
- Par défaut un transport SMTP unique crée une connexion unique et la réutilise pour
- toute la durée de la vie du script. Vous pouvez envoyer plusieurs courriels à travers cette
- connexion SMTP. Une commande RSET doit être envoyée avant chaque distribution pour garantir
- que le dialogue SMTP correct est respecté.
- </para>
- <para>
- Optionally, you can also define a default From email address and name,
- as well as a default reply-to header. This can be done through the static
- methods <methodname>setDefaultFrom()</methodname> and
- <methodname>setDefaultReplyTo()</methodname>. These defaults will be used when you
- don't specify a From/Reply-to Address or -Name until the defaults are reset (cleared).
- Resetting the defaults can be done through the use of the
- <methodname>clearDefaultFrom()</methodname> and
- <methodname>clearDefaultReplyTo</methodname>.
- </para>
- <example id="zend.mail.multiple-emails.example-1">
- <title>Envoyer plusieurs courriels par connexion SMTP</title>
- <programlisting language="php"><![CDATA[
- // Créer un transport
- $config = array('name' => 'sender.example.com');
- $transport = new Zend_Mail_Transport_Smtp('mail.example.com', $config);
- // Ajouter les nom et adresses "From" & "Reply-To" pour tous les courriels
- // à envoyer
- Zend_Mail::setDefaultFrom('sender@example.com', 'John Doe');
- Zend_Mail::setDefaultReplyTo('replyto@example.com','Jane Doe');
- // Boucle à travers les messages
- for ($i = 0; $i < 5; $i++) {
- $mail = new Zend_Mail();
- $mail->addTo('studio@example.com', 'Test');
- $mail->setSubject(
- 'Démonstration - Envoyer plusieurs emails par connexion SMTP'
- );
- $mail->setBodyText('...Votre message ici...');
- $mail->send($transport);
- }
- // Effacer les valeurs par défaut
- Zend_Mail::clearDefaultFrom();
- Zend_Mail::clearDefaultReplyTo();
- ]]></programlisting>
- </example>
- <para>
- Si vous voulez avoir une connexion SMTP séparée pour chaque distribution de courriel, vous
- devez créer et détruire votre transport avant et après chaque appel de la méthode
- <methodname>send()</methodname>. Ou sinon, vous pouvez manipuler la connexion entre chaque
- distribution en accédant à l'objet de protocole de transport.
- </para>
- <example id="zend.mail.multiple-emails.example-2">
- <title>Contrôler manuellement la connexion de transport</title>
- <programlisting language="php"><![CDATA[
- // Créer un transport
- $transport = new Zend_Mail_Transport_Smtp();
- $protocol = new Zend_Mail_Protocol_Smtp('mail.example.com');
- $protocol->connect();
- $protocol->helo('sender.example.com');
- $transport->setConnection($protocol);
- // Boucle à travers les messages
- for ($i = 0; $i < 5; $i++) {
- $mail = new Zend_Mail();
- $mail->addTo('studio@example.com', 'Test');
- $mail->setFrom('studio@example.com', 'Test');
- $mail->setSubject(
- 'Démonstration - Envoyer plusieurs emails par connexion SMTP'
- );
- $mail->setBodyText('...Votre message ici...');
- // Contrôler manuellement la connexion
- $protocol->rset();
- $mail->send($transport);
- }
- $protocol->quit();
- $protocol->disconnect();
- ]]></programlisting>
- </example>
- </sect1>
|