Raccourcis : Contenu - rubriques - sous rubriques
EN FR

jMailer est une classe permettant l'envoi d'email depuis un contrôleur ou une classe métier. Elle est basée sur la classe PHPMailer.

Voici ses possibilités :

  • envoi de pièces jointes
  • Email en HTML ou text
  • Destinataires multiples
  • Plusieurs méthodes d'envoi
  • Support de l'authentification SMTP

De nombreux exemples d'utilisation sont disponibles sur internet. Aussi nous n'allons pas détailler la manière dont on utilise cette classe.

Cependant jMailer apporte quelques fonctionnalités supplémentaires et une façon particulière de configurer l'envoi de mail :

  • la configuration générale d'envoi de mail est indiqué dans le fichier de configuration de votre application
  • possibilité d'utiliser les templates jTpl pour générer le contenu des mails.
  • messages d'erreurs traduisible via les fichier properties de jLocale.
  • les erreurs sont renvoyées via des exceptions.

Paramétrage de base

Le paramétrage de base utilisé par jMailer s'effectue dans le fichier var/config/defaultconfig.ini.php de votre application dans la section [mailer].

Les différentes options de configuration

  • webmasterEmail : l'email par defaut utilisé pour l'envoi des mails (expéditeur)
  • webmasterName : le nom par défaut utilisé pour l'envoi des mails (expéditeur)
  • mailerType : méthode utilisée pour envoyer les emails (par défaut mail)
    • "mail" : utilise la fonction mail de PHP
    • "sendmail" : utilise directement la fonction mail du serveur
    • "smtp" : utilise une connexion directe à un/plusieurs hôte SMTP
  • hostname : utilisé dans les en-têtes Message-Id et Received, et aussi comme valeur par defaut pour HELO. Si vide, utilisera la valeur renvoyée par $_SERVER['SERVER_NAME'] ou "localhost.localdomai".
  • sendmailPath : pour l'envoi par sendmail, le chemin de l'executable sendmail.

Pour l'envoi par SMTP :

  • smtpHost : le nom du serveur smtp
  • smtpPort : le port SMTP
  • smtpSecure : connection sécurisée ou pas (valeurs possibles: "", "ssl", "tls")
  • smtpHelo : le message HELO de SMTP
  • smtpAuth : on/off. Active ou non l'authentification SMTP
  • smtpUsername : le login pour se connecter sur le serveur
  • smtpPassword : le mot de passe pour se connecter sur le serveur
  • smtpTimeout : la durée maximale de tentative de connection au serveur SMTP.

jMailer utilise aussi les paramètres généraux locale et charset pour configurer la langue et l'encodage des mails.

Bien sûr, tout ces paramètres sont modifiables pour des besoins ponctuels en utilisant les méthodes et propriétés adéquates.

Envoi d'un email basique

Envoi d'un email texte avec le paramétrage par défaut.


  $mail = new jMailer();

  $mail->Subject = 'Sujet de l\'email';
  $mail->Body = 'Contenu du message texte';

  $mail->AddAddress('destinataire@exemple.com' , 'Nom du destinataire');

  $mail->Send();

Envoi d'un email basé sur un fichier jTpl

Vous pouvez utiliser toutes la puissance de jTpl a l'intérieur de vos mail. Pour Cela il vous suffit de créer un fichier .tpl dans l'un de vos module.

ex :

modules/monmodule/templates/supermail.tpl


    {meta Subject 'Super mail.'}
    {meta Priority 1}
    {meta From 'votre nom<votre@mail.com>'}
    {meta Sender 'votre@mail.com'}
    {meta ReplyTo array('votre nom<votre@mail.com>')}
    {meta to array($name.'<'.$email.'>')}
    {meta cc array('titi <titi@example.com>')}
    {meta bcc array('tutu <tutu@example.com>')}

    Salut {$name},

    Voici un super mail généré par jMailer et Jelix.

Et dans votre code PHP:


    $mail = new jMailer();
    $tpl = $mail->Tpl('monmodule~supermail');
    $tpl->assign('name', 'Monsieur Toto');
    $tpl->assign('email', 'toto@example.com');
    $mail->Send();

Il est à noter que jMailer créé des variables de templates correspondantes à des propriétés (protégées) de PHPMailer. Vous pouvez ainsi y accéder dans votre template.


    {meta Subject 'Super mail.'}
    {meta Priority 1}
    {meta From 'votre nom<votre@mail.com>'}
    {meta Sender 'votre@mail.com'}
    {meta ReplyTo array('votre nom<votre@mail.com>')}
    {meta to array($name.'<'.$email.'>')}
    {meta cc array('titi <titi@example.com>', 'tutu <tutu@example.com>')}

    Salut {$name},

    Voici un super mail généré par jMailer et Jelix. Il est en copie à :
    {foreach $cc as $person}
      - {$person[0]}
    {/foreach}

Envoi d'un email en HTML

Pour envoyer un email en HTML, il suffit d'appeler la méthode isHTML comme dans l'exemple suivant :


$mail = new jMailer();
$mail->isHTML(true);
$mail->Body = "<p>Envoi d'un mail en <strong>HTML</strong> !</p>";
$mail->AddAddress('toto@example.com' , 'Toto');
$mail->Send();

Si vous utilisez un template, indiquer true à la méthode Tpl.


$tpl = $mail->Tpl('monmodule~supermail', true);

Envoi d'un email avec pièce jointe

L'envoi de fichier en pièce jointe se fait très simplement, en donnant le chemin du fichier stocké sur le disque, et le nom que l'on veut faire apparaitre.


$mail = new jMailer();
$mail->AddAttachment(JELIX_APP_VAR_PATH.'nom_fichier_original.pdf', 'nom_fichier_pour_email.pdf');
...
$mail->Send();

Utiliser les fonctionnalités avancées de jMailer

jMailer utilise comme base PHPMailer, si vous voulez avoir d'avantage de documentation, consultez l'aide en ligne de PHPMailer.