【发布时间】:2009-10-26 10:40:29
【问题描述】:
我知道通过我的 cPanel 托管,我可以将电子邮件收件箱通过管道传输到脚本,但我想做的是:
- 发送至hi@hi.com
- 到 mail.php 的管道
- mail.php 读取主题,以及一个 .txt 附件
- 主题和.txt附件的内容存储在数据库中
有没有办法用简单的 PHP 做到这一点?
【问题讨论】:
我知道通过我的 cPanel 托管,我可以将电子邮件收件箱通过管道传输到脚本,但我想做的是:
有没有办法用简单的 PHP 做到这一点?
【问题讨论】:
存在一个名为php-mime-mail-parser 的PHP 库,它本身依赖于PECL mailparse library。当你安装了这些之后,实现你想要的代码就很简单了:
<?php
require_once 'MimeMailParser.class.php';
$parser = new MimeMailParser();
$parser->setStream(STDIN);
$subject = $parser->getHeader('subject');
$attachment_content = false;
foreach ($parser->getAttachments() as $attachment) {
$extension = pathinfo($attachment->filename, PATHINFO_EXTENSION);
if ($extension == "txt") {
$attachment_content = $attachment->content;
break;
}
}
// adapt to what ever database you are using
$sth = $mysqli->prepare("INSERT INTO mails (subject, attachment) VALUES (:subject, :attachment)");
$sth->bindParam(':subject', $subject, PDO::PARAM_STR);
$sth->bindParam(':attachment', $attachment_content, PDO::PARAM_STR);
$sth->execute();
您可以将邮件通过管道传输到脚本中,因为它从STDIN 读取。您还可以通过将setStream 更改为setPath 来读取文件。请参阅documentation of the library。
【讨论】:
您可能需要执行以下操作:
编写一个可在 CLI 中执行的 PHP 脚本(通过在指向 PHP 二进制文件的脚本顶部添加 #! 声明,然后设置其可执行权限)。
获取该脚本以从 php://stdin 读取原始电子邮件(file_get_contents 最简单)
使用 PEAR::Mail::Mime::Decode 之类的工具获取该脚本以将邮件解码为多个部分,或者我认为有一个方便的 Zend Framework 组件。
从解码后的邮件中读取附件和主题,并正常存储
exit(0) 最后告诉 CLI 这是一个干净的退出 - 任何其他 exit() 状态都可能导致退回电子邮件。
【讨论】: