phpmailer发送phpexcel导出附件

phpmailer发送phpexcel导出附件

思路

  1. 导入phpmailer及phpexcel所需文件
  2. 调用phpexcel导出函数(封装好)
  3. 将phpexcel导出文件保存在服务器并返回文件路径
  4. 调用phpmailer的发送函数进行邮件发送(封装好)
  5. 常见问题

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邮箱之后找到设置链接,选择上方的账户模块,则可看到授权码的获取,跟着流程走。如还有不懂请自行百度获取流程。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值