Introduction au Zend Framework

 Apprendre Zend Framework

appendix

 Guide de référence Zend Framework


  •  Zend_Gdata
  •  Zend_Http
  •  Zend_InfoCard
  •  Zend_Json
  •  Zend_Layout
  •  Zend_Ldap
  •  Zend_Loader
  •  Zend_Locale
  •  Zend_Log
  •  Zend_Mail
  •  Zend_Markup
  •  Zend_Measure
  •  Zend_Memory
  •  Zend_Mime
  •  Zend_Navigation
  •  Zend_Oauth
  •  Zend_OpenId
  •  Zend_Paginator
  •  Zend_Pdf
  •  Zend_ProgressBar
  •  Zend_Queue
  •  Zend_Reflection
  •  Zend_Registry
  •  Zend_Rest

  •  Zend_Search_Lucene
  •  Zend_Serializer
  •  Zend_Server
  •  Zend_Service
  •  Zend_Session
  •  Zend_Soap
  •  Zend_Tag
  •  Zend_Test
  •  Zend_Text
  •  Zend_TimeSync
  •  Zend_Tool
  •  Zend_Tool_Framework
  •  Zend_Tool_Project
  •  Zend_Translate
  •  Zend_Uri
  •  Zend_Validate
  •  Zend_Version
  •  Zend_View
  •  Zend_Wildfire
  •  Zend_XmlRpc
  • ZendX_Console_Process_Unix
  • ZendX_JQuery
  • Translation 61.2% Update 2010-11-28 - Revision 23149 - Version ZF 1.11.x

    45.3. Envoyer plusieurs courriels par connexion SMTP

    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é.

    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 setDefaultFrom() and setDefaultReplyTo(). 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 clearDefaultFrom() and clearDefaultReplyTo.

    Exemple 45.4. Envoyer plusieurs courriels par connexion SMTP

    // 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();

    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 send(). Ou sinon, vous pouvez manipuler la connexion entre chaque distribution en accédant à l'objet de protocole de transport.

    Exemple 45.5. Contrôler manuellement la connexion de transport

    // 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();

    digg delicious meneame google twitter technorati facebook

    Comments

    Loading...