使用PHP发送邮件的代码例子 - Inzaghi-iOS开发博客,互联网资讯,米兰新闻

使用PHP发送邮件的代码例子

 

使用封装SMTP协议的邮件类

这种方法就比较常见了,尤其对于广大自己没有服务器,从网上购买虚拟主机的同学,

不过我比较推荐使用PEAR扩展中的Mail类,功能强大:可以支持纯文本、HTML格式的邮件;各字段都可设置编码,正确配置不会出现中文乱码情况;可以支持附件等等。

在服务器可以使用 pear install Mail 命令快速安装,没有足够服务器权限的同学也可以直接下载类的PHP源码包含进来就可以了。

注:Mail类依赖  Net/SMTP.php  和 Mail/mime.php ,要一块下载,使用时一块包含进来。

详细安装方法可以在官网查看,http://pear.php.net/package/Mail

下面我举例说明一下在Mail类发送邮件的方法吧,网上其他SMTP邮件类使用方法一块也类似,可以参考:

 

<?php

// Pear Mail 扩展
require_once(‘Mail.php’);
require_once(‘Mail/mime.php’);
require_once(‘Net/SMTP.php’);

$smtpinfo = array();
$smtpinfo[“host”] = “smtp.163.com”;//SMTP服务器
$smtpinfo[“port”] = “25”; //SMTP服务器端口
$smtpinfo[“username”] = “username@163.com”; //发件人邮箱
$smtpinfo[“password”] = “password”;//发件人邮箱密码
$smtpinfo[“timeout”] = 10;//网络超时时间,秒
$smtpinfo[“auth”] = true;//登录验证
//$smtpinfo[“debug”] = true;//调试模式

// 收件人列表
$mailAddr = array(‘receiver@163.com’);

// 发件人显示信息
$from = “Name <username@163.com>”;

// 收件人显示信息
$to = implode(‘,’,$mailAddr);

// 邮件标题
$subject = “这是一封测试邮件”;

// 邮件正文
$content = “<h3>随便写点什么</h3>”;

// 邮件正文类型,格式和编码
$contentType = “text/html; charset=utf-8”;

//换行符号 Linux: \n Windows: \r\n
$crlf = “\n”;
$mime = new Mail_mime($crlf);
$mime->setHTMLBody($content);

$param[‘text_charset’] = ‘utf-8’;
$param[‘html_charset’] = ‘utf-8’;
$param[‘head_charset’] = ‘utf-8’;
$body = $mime->get($param);

$headers = array();
$headers[“From”] = $from;
$headers[“To”] = $to;
$headers[“Subject”] = $subject;
$headers[“Content-Type”] = $contentType;
$headers = $mime->headers($headers);

$smtp =& Mail::factory(“smtp”, $smtpinfo);
$mail = $smtp->send($mailAddr, $headers, $body);
$smtp->disconnect();

if (PEAR::isError($mail)) {
//发送失败
echo ‘Email sending failed: ‘ . $mail->getMessage().”\n”;
}
else{
//发送成功
echo “success!\n”;
}

?>

结论:这种方式发送邮件无需装任何软件,只需要包含进来一个PHP类,然后多写几行配置代码,就可以了。并且网上有很多示例的代码,很多时候只要复制过来然后修改个别的几个参数就可以用了,所以会很方便,推荐使用此方法。

 

标签:
,
分类:SERVER | 发布:inzaghi | 评论:0 条 | 发表时间:2017-02-7 15:20
引用:点击这里获取该日志的TrackBack引用地址
上一篇:
下一篇:

发表评论

*

* 绝不会泄露


Design By Inzaghi | 京ICP备16047555号-1