1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94
|
<?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>
|