phpmailer发送phpexcel导出附件
思路
- 导入phpmailer及phpexcel所需文件
- 调用phpexcel导出函数(封装好)
- 将phpexcel导出文件保存在服务器并返回文件路径
- 调用phpmailer的发送函数进行邮件发送(封装好)
- 常见问题
phpexcel导出函数(Excel类)
public function daochu($title,$tableheader,$data,$letter='',$async=''){
require_once(dirname(__FILE__).'/../PHPExcel/PHPExcel.php'); //引入所需要的的文件
//创建对象
//$excel = new \PHPExcel();
$excel = new \PHPExcel();
//Excel表格式,这里简略写了8列
if(!$letter){
$letter = array('A','B','C','D','E','F','G','H','I','J','K');
}
//设置宽度
foreach ($letter as $key => $value) {
$excel->getActiveSheet()->getColumnDimension("$value")->setWidth(20);
}
//表头数组
//$tableheader = array();
//填充表头信息
for($i = 0;$i < count($tableheader);$i++) {
$excel->getActiveSheet()->setCellValue("$letter[$i]1","$tableheader[$i]");
}
//表格数组
//填充表格信息
for ($i = 2;$i <= count($data) + 1;$i++) {
$j = 0;
foreach ($data[$i - 2] as $key=>$value) {
$excel->getActiveSheet()->setCellValue("$letter[$j]$i","$value");
$j++;
}
}
//创建Excel输入对象
$write = new \PHPExcel_Writer_Excel5($excel);
if ($async){
$filename=$title."_".date('YmdHis',time()).".xls";
$filenames = iconv("utf-8","gb2312",$filename);
$return_url = './Uploads/ajax_out_file/'.$filename;
$url = './Uploads/ajax_out_file/'.$filenames; //保存到服务器上的路径
$write->save($url);
return $return_url;
}
header("Pragma: public");
header("Expires: 0");
header("Cache-Control:must-revalidate, post-check=0, pre-check=0");
header("Content-Type:application/force-download");
header("Content-Type:application/vnd.ms-execl");
header("Content-Type:application/octet-stream");
header("Content-Type:application/download");
$filename=$title."_".date('Y_m_d',time()).".xls";
header('Content-Disposition:attachment;filename="'.$filename.'"');
header("Content-Transfer-Encoding:binary");
$write->save('php://output');
}
phpexcel保存文件函数
public function contract_daochu(){
$tableheader=array('','','','','',''); //表头
$zimu=array('A','B','C','D','E','F'); //列数
$data = array();
//从数据表数据存放于data数组
if(!$data){
$data=array(
array('','')
);
}
$title='表格标题';
$test=new Excel();
return $test->daochu($title,$tableheader,$data,$zimu,1);
}
phpmailer导出函数(phpmailer类)
//发送邮件($to:发送账号 $title:邮件标题 $content:邮件内容 $path:附件路径)
protected function sendMail($to, $title, $content,$path)
{
//引入PHPMailer的核心文件 使用require_once包含避免出现PHPMailer类重复定义的警告
require_once(APP_PATH . "Admin/PHPMailer/class.phpmailer.php");
require_once(APP_PATH . "Admin/PHPMailer/class.smtp.php");
//实例化PHPMailer核心类
$mail = new \PHPMailer();
//是否启用smtp的debug进行调试 开发环境建议开启 生产环境注释掉即可 默认关闭debug调试模式
$mail->SMTPDebug = 1;
//使用smtp鉴权方式发送邮件
$mail->isSMTP();
//smtp需要鉴权 这个必须是true
$mail->SMTPAuth = true;
//链接qq域名邮箱的服务器地址
$mail->Host = 'smtp.qq.com';
//设置使用ssl加密方式登录鉴权
$mail->SMTPSecure = 'ssl';
//设置ssl连接smtp服务器的远程服务器端口号,以前的默认是25,但是现在新的好像已经不可用了 可选465或587
$mail->Port = 465;
//设置smtp的helo消息头 这个可有可无 内容任意
// $mail->Helo = 'Hello smtp.qq.com Server';
//设置发件人的主机域 可有可无 默认为localhost 内容任意,建议使用你的域名
//$mail->Hostname = 'http://www.lsgogroup.com';
//设置发送的邮件的编码 可选GB2312 我喜欢utf-8 据说utf8在某些客户端收信下会乱码
$mail->CharSet = 'UTF-8';
//设置发件人姓名(昵称) 任意内容,显示在收件人邮件的发件人邮箱地址前的发件人姓名
$mail->FromName = '';
//smtp登录的账号 这里填入字符串格式的qq号即可
$mail->Username = '';
//smtp登录的密码 使用生成的授权码(就刚才叫你保存的最新的授权码)
$mail->Password = ';
//设置发件人邮箱地址 这里填入上述提到的“发件人邮箱”
$mail->From = '';
//邮件正文是否为html编码 注意此处是一个方法 不再是属性 true或false
$mail->isHTML(true);
//设置收件人邮箱地址 该方法有两个参数 第一个参数为收件人邮箱地址 第二参数为给该地址设置的昵称 不同的邮箱系统会自动进行处理变动 这里第二个参数的意义不大
$mail->addAddress($to, 'lsgo在线通知');
//添加多个收件人 则多次调用方法即可
// $mail->addAddress('xxx@163.com','lsgo在线通知');
//添加该邮件的主题
$mail->Subject = $title;
//添加邮件正文 上方将isHTML设置成了true,则可以是完整的html字符串 如:使用file_get_contents函数读取本地的html文件
$mail->Body = $content;
//为该邮件添加附件 该方法也有两个参数 第一个参数为附件存放的目录(相对目录、或绝对目录均可) 第二参数为在邮件附件中该附件的名称
$mail->addAttachment($path);
//同样该方法可以多次调用 上传多个附件
// $mail->addAttachment('./Jlib-1.1.0.js','Jlib.js');
$status = $mail->send();
//简单的判断与提示信息
if ($status) {
return true;
} else {
return false;
}
}
测试函数
public function test()
{
$to = ''; //接收人
$title = ''; //邮件标题
$content = ''; //文件内容
$status = '';
$home = new 保存导出文件路径的类;
$path = $home->contract_daochu();
$status = $this->sendMail($to, $title, $content,$path); //发送邮件
if ($status) {
dump("邮件发送成功");
} else {
dump("邮件发送失败");
}
}
常见问题
1.若出现无法访问文件,大概率是保存文件的路径出错,认真检查即可。
2.phpmailer发送函数需要授权码,本人用的是QQ邮箱,登录QQ邮箱之后找到设置链接,选择上方的账户模块,则可看到授权码的获取,跟着流程走。如还有不懂请自行百度获取流程。