File: Zend_Mail-MultipleEmails.xml

package info (click to toggle)
zendframework 1.12.9%2Bdfsg-2
  • links: PTS, VCS
  • area: main
  • in suites: jessie-kfreebsd
  • size: 133,584 kB
  • sloc: xml: 1,311,829; php: 570,173; sh: 170; makefile: 125; sql: 121
file content (94 lines) | stat: -rw-r--r-- 3,503 bytes parent folder | download | duplicates (2)
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>