2014-12-28 20:27:36
来 源
中存储网
sendmail
一、介绍mail()函数,你能用此函数发送电子邮件。需求为了能使用Mail函数,在你的系统中,PHP必须有编译发送二进制邮件文件的权力。如果你用其它的邮件程序,例如qmail或postfix,你必须有把握使用它们发送邮件包。PHP将首先在你的路径上寻找

一、介绍
mail()函数,你能用此函数发送电子邮件。
需求
为了能使用Mail函数,在你的系统中,PHP必须有编译发送二进制邮件文件的权力。如果你用其它的邮件程序,例如qmail或postfix,你必须有把握使用它们发送邮件包。PHP将首先在你的路径上寻找sendmail,于是下列各项路径: :/usr/bin :/usr/sbin :/usr/etc :/etc:/usr/ucblib :/usr/lib是被推荐的。同样编译PHP的使用者一定有存取二进制的sendmail权力。
安装
这些函数作为 PHP 核心的一部分,无需被安装即可使用。
运行时配置
这些函数的行为受到全局配置文件 php.ini 的影响。
表格 1. Mail基本配置选项:

名称 默认值 可改变值
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

为了更多的有关Mail的配置选项请看see ini_set()函数。以下是该配置选项的简要解释。
SMTP string
仅用在Windows: SMTP服务器的DNS名字或IP地址。PHP在用mail()函数发送邮件时将用SMTP服务器。
smtp_portint
仅用在Windows:当用mail()函数发送邮件时设置连接到指定SMTP服务器的端口号,默认: 25。仅在PHP 4.3.0后可用。
sendmail_from string
PHP在Windows系统中发送邮件时,将用"From:"邮件地址。
sendmail_path string
在什么地方找到发送邮件程序。通常在: /usr/sbin/sendmail或/usr/lib/中。在这配置选项为了你能正常工作而设置了一个默认值。但是如果它失败,你能在这里设定它。
如果系统不能使用sendmail,应该按这个指示设置sendmail包裹器/ 替换他们提供的邮件系统。举例来说,Qmail使用者能设置它到新的路径: /var/qmail/bin/sendmail或/var/qmail/bin/qmail-inject。
qmail-正确地处理邮件而不需要任何的选项。
资源类型
该扩展模块未定义任何资源类型。
预定义常量
该扩展模块未定义任何常量

二、使用方法

语法:   
bool mail ( string to, string subject, string message [, string additional_headers [, string additional_parameters]])   
mail()函数可以发送指定的消息(string message)到指定的邮件地址(string to)。多个邮件地址之间要用逗号分割。能用这个函数发送邮件附件和特殊类型。   
在上面的语法中的各个参数代表的意思是:
string to——收件人的email地址、
string subject——email的主题、
string message——email的正文、
string additional_headers——加email的附加信息到信件头尾部。   
如果邮件成功的被发送mail()函数将返回TRUE,否则返回FALSE。 注意!   

mail()函数在Windows中的执行方法有很多地方不同于UNIX系统。   
1、它不用局部二进制构成消息体;   
2、类似 From:, Cc:, Bcc:和Date:的headers头元素,首先不被MTA解释,但能被PHP解释。 PHP < 4.3仅支持 Cc:且区分大小写, PHP >= 4.3支持所有提及的headers头元素而且不区分大小写。
二.一、例子 1、发送邮件:

mail("joecool@example.com", "My Subject", "Line 1nLine 2nLine 3");

 二.二、如果使用第四个参数,这个参数字串将插入信件头尾部。这是典型的插入用于说明附加信件头信息。多个附加信件头信息之间要用回车r和换行n符隔开。
例子 2. 发送附加信件头信息邮件:

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

二.三、如果用additional_parameters参数,当发送邮件时程序用sendmail_path配置设置一个附加参数。例如,当在邮件前用-f选项时这能用来设定寄件人地址信封。当你用这个方法设置寄件人信封时,你也许需要加那个用户到你的WEB服务器You may need to add the user that your web server runs as to your sendmail configuration to prevent a ’X-Warning’ header from being added to the message when you set the envelope sender using this method.
例子 3. 发送附加的信件头信息邮件而且附加一个指令参数。

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

 注意:其中的第五个参数附加在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>

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

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

声明: 此文观点不代表本站立场;转载须要保留原文链接;版权疑问请联系我们。