Maison > développement back-end > tutoriel php > Explication détaillée des exemples d'utilisation de la fonction php mail() pour envoyer des e-mails

Explication détaillée des exemples d'utilisation de la fonction php mail() pour envoyer des e-mails

伊谢尔伦
Libérer: 2023-03-11 15:24:02
original
3149 Les gens l'ont consulté

1. Introduction
Fonction Mail(), vous pouvez utiliser cette fonction pour envoyer des e-mails.
Exigences
Afin d'utiliser la fonction Mail, PHP doit avoir la capacité de compiler et d'envoyer des fichiers courrier binaires dans votre système. Si vous utilisez d'autres programmes de messagerie, tels que qmail ou postfix, vous devez être sûr de pouvoir les utiliser pour envoyer des paquets de courrier. PHP recherchera d'abord sendmail sur votre chemin, donc les chemins suivants : :/usr/bin :/usr/sbin :/usr/etc :/etc:/usr/ucblib :/usr/lib sont recommandés. Les utilisateurs qui compilent PHP doivent également avoir accès au sendmail binaire.
Installation
Ces fonctions font partie du noyau PHP et peuvent être utilisées sans être installées.
Configuration du runtime
Le comportement de ces fonctions est affecté par le fichier de configuration php.ini global.
Tableau 1. Options de configuration de base de Mail :

Nom Valeur par défaut Valeur modifiable

SMTP "localhost" PHP_INI_ALL

smtp_port "25" PHP_INI_ALL

sendmail_from NULL PHP_INI_ALL

sendmail_path DEFAULT_SENDMAIL_PATH PHP_INI_SYSTEM

Pour plus d'options de configuration sur Mail, veuillez consulter la fonction ini_set(). Ce qui suit est une brève explication de cette option de configuration.
Chaîne SMTP
 Utilisé uniquement sous Windows : nom DNS ou adresse IP du serveur SMTP. PHP utilisera le serveur SMTP lors de l'envoi d'e-mails à l'aide de la fonction mail().
smtp_portint
Utilisé uniquement sous Windows : définissez le numéro de port pour se connecter au serveur SMTP spécifié lors de l'envoi de courrier à l'aide de la fonction mail(). Par défaut : 25. Uniquement disponible après PHP 4.3.0.
sendmail_from string
Lorsque PHP envoie des e-mails dans les systèmes Windows, il utilisera l'adresse e-mail « De : ».
sendmail_path string
Où trouver le programme d'envoi de courrier. Généralement dans : /usr/sbin/sendmail ou /usr/lib/. Les options de configuration ici sont définies sur une valeur par défaut afin qu'elles fonctionnent correctement pour vous. Mais si cela échoue, vous pouvez le définir ici.
Si votre système ne peut pas utiliser sendmail, vous devez suivre ces instructions pour configurer un wrapper/remplacement sendmail pour le système de messagerie qu'ils fournissent. Par exemple, les utilisateurs de Qmail peuvent lui attribuer un nouveau chemin : /var/qmail/bin/sendmail ou /var/qmail/bin/qmail-inject.
qmail - gère le courrier correctement sans aucune option.
Type de ressource
Ce module d'extension ne définit aucun type de ressource.
Constantes prédéfinies
Ce module d'extension ne définit aucune constante

2. Utilisation
Syntaxe : ​

bool mail ( string to, string subject, string message [, string additional_headers [, string additional_parameters]])   
Copier après la connexion

mail La fonction () peut envoyer le message spécifié (chaîne de message) à l'adresse e-mail spécifiée (chaîne à). Plusieurs adresses e-mail doivent être séparées par des virgules. Vous pouvez utiliser cette fonction pour envoyer des pièces jointes à des e-mails et des types spéciaux.
La signification de chaque paramètre dans la syntaxe ci-dessus est :
chaîne à - l'adresse e-mail du destinataire,
chaîne sujet - le sujet de l'e-mail,
chaîne message - le corps de l'e-mail,
string supplement_headers - ajoute des informations de courrier électronique supplémentaires à l'en-tête et à la fin de la lettre.
Si l'e-mail est envoyé avec succès, la fonction mail() retournera TRUE, sinon elle retournera FALSE. Avis! ​

La méthode d'exécution de la fonction mail() sous Windows est différente des systèmes UNIX à bien des égards.  
 1. Il n'utilise pas de binaire local pour former le corps du message ;    
 2. Les éléments d'en-tête comme From :, Cc :, Bcc : et Date : ne sont pas interprétés en premier par MTA, mais peuvent être interprétés par PHP. PHP < 4.3 ne prend en charge que Cc : et est sensible à la casse, PHP >= 4.3 prend en charge tous les éléments d'en-tête mentionnés et n'est pas sensible à la casse.
 2.1. Exemple 1. Envoyer un e-mail :

mail("joecool@example.com", "My Subject", "Line 1nLine 2nLine 3");
Copier après la connexion

 2.2. Si le quatrième paramètre est utilisé, cette chaîne de paramètre sera insérée dans l'en-tête et la queue de la lettre. Ceci est généralement inséré pour illustrer des informations d’en-tête supplémentaires. Plusieurs informations d'en-tête supplémentaires doivent être séparées par des caractères de retour chariot r et de saut de ligne n.
Exemple 2. Envoyer un e-mail d'informations d'en-tête supplémentaire :

mail("nobody@example.com", "the subject", $message,"From: webmaster@{$_SERVER[’SERVER_NAME’]}rn"    
."Reply-T webmaster@{$_SERVER[’SERVER_NAME’]}rn"."X-Mailer: PHP/" .phpversion());
Copier après la connexion

2.3 Si le paramètre supplement_parameters est utilisé, le programme utilise la configuration sendmail_path pour définir un paramètre supplémentaire lors de l'envoi de l'e-mail. Par exemple, cela peut être utilisé pour définir l'enveloppe d'adresse de l'expéditeur lors de l'utilisation de l'option -f avant l'envoi. Lorsque vous configurez l'enveloppe de l'expéditeur à l'aide de cette méthode, vous devrez peut-être ajouter l'utilisateur que votre serveur Web exécute à votre configuration sendmail pour empêcher qu'un en-tête « X-Warning » soit ajouté au message lorsque vous définissez l'expéditeur de l'enveloppe en utilisant cette méthode.
Exemple 3. Envoi d'un e-mail avec des informations d'en-tête supplémentaires et ajout d'un paramètre de commande.

mail("nobody@example.com", "the subject", $message,"From: webmaster@{$_SERVER[’SERVER_NAME’]}",      
 "-fwebmaster@{$_SERVER[’SERVER_NAME’]}");
Copier après la connexion

  注意:其中的第五个参数附加在PHP 4.0.5版本中。在PHP 4.2.3以后的版本中的安全模式中被禁止,如果用它的话将返回一个警告信息和返回FALSE值。   
  你同样能用简单的字符串构造技术建立一个复杂的邮件消息。
例子 4. 发送一个复杂邮件

/*收件人*/
$to = "Mary " . ", " ; //注意逗号
$to .= "Kelly ";
 /*主题*/
$subject = "Birthday Reminders for August";
/*正文*/
$message = ’         
Here are the birthdays upcoming in August!
’;
 /*你能设置头内容:Content-type来发送HTML格式邮件。*/
 $headers = "MIME-Version: 1.0rn";
$headers .= "Content-type: text/html; charset=iso-8859-1rn";
 /*附加头消息*/
$headers .= "From: Birthday Reminder rn";
$headers .= "Cc: birthdayarchive@example.comrn";
$headers .= "Bcc: birthdaycheck@example.comrn";
/*发送它*/
mail($to, $subject, $message, $headers);
@example.com>@example.com>@example.com>
Copier après la connexion

注意:
  1、不要在收件人地址和主题中有换行符号,否则邮件可能不能被发送出去。
  2、收件人地址参数(string to)中不能存在以"Something "形式地址,否则当用MTA时mail命令可能不被正确的分析。
  3、PHP使用mail函数发送邮件标题乱码问题 PHP程序使用mail()函数发送邮件的时候,标题中文的话会出现乱码。
解决方法:
  先用函数base64_encode() — 使用 MIME base64 对数据进行编码 标题字符串前加编码类型例如: =?UTF-8?B? 标题字符串后加:?= 邮件header说明Content-type — 防止邮件正文也乱码
举例:

$to  = &#39;xinple@example.com&#39;;
$subject  = "=?UTF-8?B?".base64_encode(&#39;邮件标题&#39;)."?=";
$headers  = &#39;MIME-Version: 1.0&#39; . "rn";
$headers .= &#39;Content-type: text/html; charset=utf-8&#39; . "rn";
// Additional headers
$headers .= &#39;To: Xinple&#39; . "rn";
$headers .= &#39;From: Admin &#39; . "rn";
$headers .= &#39;Reply-To: Xinple&#39; . "rn";
mail($to, $subject, $message, $headers);@example>@example.com>@example.com
Copier après la connexion

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal