想生成一个docx文件并使用PHP将其作为附件发送(PHPMailer)

时间:2013-09-16 19:51:13

标签: php phpmailer email-attachments phpword

我已经创建了一份患者医疗报告表,我的工作是要生成一个正确的格式化和兼容的 docx 文件(主要包括表格和段落),其中填写的表格收到的值并发送给它作为附件而不保存在任何地方。

要创建docx文件,我想使用 PHPWord 插件,我也尝试HTMLtoDOCX生成docx,但我想在附件中发送动态生成的docx文件。 (不要告诉我使用 PHPDocx ,因为我有它的社区版本,并且它生成空白文件或文件少于添加的文件)

我正在使用 PHPMailer 发送电子邮件。我不想附加文件使用 AddAttachment 功能,因为它用于位于某处的永久文件。

目前,我可以使用 PHPMailer 发送动态生成的 doc 文件,但该文件与 MS Word 2010 的代码不兼容生成doc文件并将其作为附件发送:

    $separator = md5(time());

    $eol = PHP_EOL;

    $headers  = "MIME-Version: 1.0".$eol;
line-4  // $headers .= "Content-Type: application/vnd.openxmlformats-officedocument.wordprocessingml.document".$eol;
line-5  // $headers .= "Content-Type: application/vnd.ms-word.document.macroEnabled".$eol;

    // attachment name
    $filename = $a1 . " Medical Report.doc";

    // Report Document

    $report  = "                    ".$a1 . " Medical Report".$eol.$eol.$eol;
    $report .= "NAME                            |            ".$a1.$eol;
    $report .= "HOSPITAL No.                    |            ".$a2.$eol;
    $report .= "DATE of BIRTH                   |            ".$a3.$eol;
    $report .= "SEX                             |            ".$a4.$eol;
    $report .= "DATE of FOLLOW UP               |            ".$a5.$eol;
    $report .= "DATE of IMPLANT                 |            ".$a6.$eol;
    $report .= "PACEMAKER                       |            ".$a7.$eol;
    $report .= "MODEL                           |            ".$a8.$eol;
    $report .= "PROGRAMMED RATE(bpm)            |            ".$a9.$eol;
    $report .= "MAGNET RATE(bpm)                |            ".$a10.$eol;
    $report .= "EOL/ERT RATE(bpm)               |            ".$a11.$eol;
    $report .= "PROGRAMMED RATE(ms)             |            ".$a12.$eol;
    $report .= "MAGNET RATE(ms)                 |            ".$a13.$eol;
    $report .= "EOL/ERT Rate(ms)                |            ".$a14.$eol;
    $report .= "ATRIAL(amp)                     |            ".$a15.$eol;
    $report .= "RIGHT VENTRICLE(amp)            |            ".$a16.$eol;
    $report .= "LEFT VENTRICLE(amp)             |            ".$a17.$eol;
    $report .= "ATRIAL(pw)                      |            ".$a18.$eol;
    $report .= "RIGHT VENTRICLE(pw)             |            ".$a19.$eol;
    $report .= "LEFT VENTRICLE(pw)              |            ".$a20.$eol;
    $report .= "ATRIAL(mv)                      |            ".$a21.$eol;
    $report .= "RIGHT VENTRICLE(mv)             |            ".$a22.$eol;
    $report .= "LEFT VENTRICLE(mv)              |            ".$a23.$eol;
    $report .= "ATRIAL(ohms)                    |            ".$a24.$eol;
    $report .= "RIGHT VENTRICLE(ohms)           |            ".$a25.$eol;
    $report .= "LEFT VENTRICLE(ohms)            |            ".$a26.$eol;
    $report .= "BATTERY IMPEDANCE               |            ".$a27.$eol;
    $report .= "CALC LONGEVITY                  |            ".$a28.$eol;
    $report .= "BATTERY VOLTAGE                 |            ".$a29.$eol;
    $report .= "ERI INDICATOR                   |            ".$a30.$eol;
    $report .= "CURRENT                         |            ".$a31.$eol;
    $report .= "STABILITY/MYO-POTENTIAL         |            ".$a32.$eol;
    $report .= "VA CONDUCTION                   |            ".$a33.$eol;
    $report .= "WOUND CHECK                     |            ".$a34.$eol;
    $report .= "ECG RHYTHM                      |            ".$a35.$eol;
    $report .= "UNDERLYING RHYTHM               |            ".$a36.$eol;
    $report .= "HISTOGRAMS %AGE PACING          |            ".$a37.$eol;
    $report .= "PATIENT SYMPTOMS                |            ".$a38.$eol;
    $report .= "COMMENTS                        |            ".$a39.$eol;
    $report .= "PROGRAMME CHANGES AND REASONS   |            ".$a40.$eol;  
    $report .= "CARDIAC PHYSIOLOGIST            |            ".$a44.$eol;
    $report .= "NEXT APPOINTMENT                |            ".$a42.$eol;



    // encode data (puts attachment in proper format)
    $attachment = chunk_split(base64_encode($report));

    ///////////HEADERS INFORMATION////////////

    // main header (multipart mandatory) message
    $headers .= "Content-Type: multipart/mixed; boundary=\"".$separator."\"".$eol.$eol; 
    $headers .= "Content-Transfer-Encoding: 7bit".$eol;
    $headers .= "This is a MIME encoded message.".$eol.$eol;

    // message
    $headers .= "--".$separator.$eol;
    $headers .= "Content-Type: text/html; charset=\"iso-8859-1\"".$eol;
    $headers .= "Content-Transfer-Encoding: 8bit".$eol.$eol;
    $headers .= $message1.$eol.$eol;

    // attachment
    $headers .= "--".$separator.$eol;
    $headers .= "Content-Type: application/octet-stream; name=\"".$filename."\"".$eol; 
    $headers .= "Content-Transfer-Encoding: base64".$eol;
    $headers .= "Content-Disposition: attachment".$eol.$eol;
    $headers .= $attachment.$eol.$eol;
    $headers .= "--".$separator."--";



    require("class.phpmailer.php");
    $mail = new PHPMailer();

    $mail->IsSMTP();   // set mailer to use SMTP
    $mail->Host = "localhost";  // specify main and backup server
    $mail->SMTPAuth = true;     // turn on SMTP authentication
    $mail->Username = "newuser"; // Make sure to replace this with your shell enabled user
    $mail->Password = "wampp";  // Make sure to use the proper password for your user


    $mail->From = "admin@localhost";
    $mail->FromName = "Admin";
    $mail->AddAddress("recepient@domain.com", "First Last");
        $mail->AddCC("recepient@domain.com");
        $mail->AddBCC("recepient@domain.com");

    $mail->AddReplyTo("admin@localhost", "Admin");

    $mail->WordWrap = 50;  // set word wrap to 50 characters
    $mail->IsHTML(true);   // set email format to HTML

    $mail->Subject = $subject;
    $mail->MsgHTML($message1);
    $mail->AddCustomHeader($headers);
    // $mail->AddAttachment($filename, 'Content-Type: application/vnd.openxmlformats-officedocument.wordprocessingml.document;application/vnd.ms.word.document.macroEnabled');

    if(!$mail->Send()){
        echo "Message could not be sent. <p>";
        echo "Mailer Error: " . $mail->ErrorInfo;
        exit;
    }
    else {
echo <<<_END
    <script>
        alert("Email Sent");
        document.location='index.html';
    </script>
_END;
    }
?>

如果我为docx注释掉第4行和第5行,那么我没有收到HTML消息,同时该文件也被更改为不同的不支持的word文件。

这个完整问题的结论是我需要根据我想要的设计或我拥有的模板正确格式化 Docx 文件,并将其作为附件发送,而不需要任何保存或下载对话框。

如果我使用这些标题,那么会出现一个带有打开和保存选项的对话框(我也不想这样)

header('Content-Description: File Transfer');
header('Content-Type: application/octet-stream');
header('Content-Disposition: attachment; filename=example.docx');
header('Content-Transfer-Encoding: binary');

我希望你们都明白我的意思。如果有人会给我正确的方向或解决方案,那么提前1000000000000000谢谢,因为我只在这个问题上浪费了2天。

2 个答案:

答案 0 :(得分:1)

您没有生成Word文件...您正在生成纯文本,然后通过伪造mime标头来修改它的Word。

鉴于您正在使用PHPMailer,您应该 NOT 尝试构建自己的MIME电子邮件 - PHPMailer已经完全可以为您完成这项工作。

至于不想使用“真实”文件来存储附件数据,您可以使用AddStringAttachment()方法:

  $mailer->AddStringAttachment($your_fake_word_file_as_a_string, 'Example.docx')

详见此处:http://phpmailer.worxware.com/index.php?pg=tutorial#3

答案 1 :(得分:0)

使用PHPWord生成Docx文件并通过邮件发送。它可以轻松添加图像,表格,字体样式和更多功能等内容,

在此处阅读有关PHPWord及其用法的更多信息。

http://www.kvcodes.com/2014/08/create-docx-files-using-php/