1

这是我用于拦截的 PHP 脚本:

#!/usr/local/bin/php -q
<?php
//Listen to incoming e-mails
$sock = fopen("php://stdin", 'r');
$email = '';

//Read e-mail into buffer
while (!feof($sock))
{
    $email .= fread($sock, 1024);
}

//Close socket
fclose($sock);

emailPoster('email@address.com', "message");

function emailPoster( $to, $email )
{
    $subject = "Email Intercepted";
    $body = $message;
    $headers    = "To: {$to}\r\n";
    $headers    .= "From: noreply@example.com\r\n";
    $headers    .= "Subject: {$subject}\r\n";
    $headers    .= "Reply-To: noreply@example.com\r\n";
    $headers    .= "Return-Path: noreply@example.com\r\n";
    $headers    .= "MIME-Version: 1.0\r\n";
    $headers    .= "Date: " . date("r") . "\r\n";
    $headers    .= "Content-Type: text/html; charset=ISO-8859-1\r\n";
    $sender     = '-fnoreply@example.com';
    if (mail($to, $subject, $body, $headers, $sender) ){
        echo("<p>Message successfully sent!</p>");
    } else {
        echo("<p>Message delivery failed...</p>");
    }
}
?>

以及我在 cPanel 中使用的管道命令:

usr/local/bin/php -q /public_html/[mywebsite]/email/intercept.php

当我向适当的地址发送电子邮件时,它会处理 intercept.php 脚本,但它也会返回一个退回错误。

有任何想法吗?

4

3 回答 3

4

如果您通过管道将电子邮件发送到 php 脚本,则不能在脚本中使用“ECHO”或其他输出命令。每个输出命令都会出错。还要从文件末尾删除“?>”。此标记之后的每个字符都会生成一个输出标题并导致错误。

于 2013-09-15T07:04:03.873 回答
0

我将其写入文件而不是 echo 语句。确保正确设置目录中的写入权限。

于 2015-01-07T12:43:08.033 回答
0

你总是可以把:

return NULL;

在您的 PHP 文件的末尾停止任何将阻止脚本弹跳的返回消息。

于 2015-07-22T15:32:51.593 回答