通过php发送邮件,错误回复到


Sending mail via php, malformed reply-to

我不得不修改我们俱乐部的活动日历,因为我们在gmails垃圾邮件过滤器方面遇到了问题。我已尝试修改以下代码,使发件人的电子邮件现在为"回复",发件人为"calendar@dsac.co.uk"希望使用来自我们自己域的电子邮件将解决垃圾邮件问题。邮件发送失败,我收到此错误"回复:缺少或格式错误的本地部分(预期单词或"<")

我已尝试将电子邮件回复更改为,但结果相同。我边学习php边学习,这些代码都不是我的,我只是想让它发挥作用。

这是我修改过的代码。

<?php
require('wordpress/wp-load.php');
get_header();
?>
<div id="container">
  <div id="content" role="main">
<?php
include ("inc/functions.inc");
include ("inc/dbconnect.inc");
$db = db_connect();
$cookie = $_COOKIE[User];
$cookiearray = explode(",",$cookie);
if (isset($_POST['to'])){
    $particode = $_POST['IDs'];
    $participants = explode(",",$particode);
    $search = "";
    $numpar = count($participants)-1;
    for ($i=0;$i<=$numpar;$i++){
        if ($search == ""){
            $search = "ID LIKE ".$participants[$i];
        }else {
            $search = $search." OR ID LIKE ".$participants[$i];
        }
    }
    $result = mysql_query("SELECT Mail FROM users WHERE ".$search, $db);
    if (!$result) {
       die('Invalid query: ' . mysql_error());
    }
    $msg = $_POST['msg'];
    $subject = $_POST['subject'];
    $numpar = mysql_num_rows($result)-1;
    for ($i=0;$i<=$numpar;$i++){
        if ($i == 0){
            $to = mysql_result($result,$i,'Mail');
        }else {
            $to = $to.", ".mysql_result($result,$i,'Mail');
        }
    }
    $result = mysql_query("SELECT Mail FROM users WHERE ID LIKE ".$cookiearray[0], $db);
    if (!$result) {
       die('Invalid query: ' . mysql_error());
    }
    $replyto = mysql_result($result,0,'Mail');

    $from = 'calendar@dsac.co.uk';
    $test = mail($to, $subject, $msg,'From: '.$from,'Reply-To: '.$replyto);

    if ($test){
        Echo "<b>Mail sent</b>";
    }else{
        echo "<b>An error has occured trying to send your mail, sorry</b>";
    }
}Else {
    $particode = $_POST['participants'];
    $participants = explode(",",$particode);
    $search = "";
    $numpar = count($participants)-1;
    for ($i=0;$i<=$numpar;$i++){
        if ($search == ""){
            $search = "ID LIKE ".$participants[$i];
        }else {
            $search = $search." OR ID LIKE ".$participants[$i];
        }
    }
    $result = mysql_query("SELECT Name FROM users WHERE ".$search, $db);
    if (!$result) {
       die('Invalid query: ' . mysql_error());
    }
    Echo "<form name='mailform' action='eventmail.php' method='POST'>'n
    <table border='0'>'n
    <tr><td><b>To:</b></td><td><textarea rows='2' cols='45' name='to' readonly>";
    for ($i=0;$i<=$numpar;$i++){
        if ($i == 0){
            echo mysql_result($result,$i,'Name');
        }else {
            echo "; ".mysql_result($result,$i,'Name');
        }
    }
    Echo "</textarea><input type='hidden' name='IDs' value='".$particode."'></td></tr>'n
    <tr><td valign='top'><b>Subject:</b></td><td><input type='text' name='subject' size='45'></td></tr>'n
    <tr><td valign='top'><b>Message:</b></td><td><Textarea name='msg' rows='20' cols='45'></textarea></td></tr>'n
    <tr><td colspan=2 valign='top'><input type='submit' value='Send mail'></td></tr></table>'n
    </form>
    ";
}
?>
</div>
</div>
<?php get_sidebar(); ?>
<?php get_footer(); ?>

谢谢。

使用此标头尝试此操作可能会奏效。

$headers = array();
$headers[] = "MIME-Version: 1.0";
$headers[] = "Content-type: text/html; charset=iso-8859-1";
$headers[] = "From: $brand_name <$from>";
$headers[] = "Bcc: Name <name@domain.com>";
$headers[] = "Reply-To: Recipient Name <receiver@domain3.com>"; 
$headers[] = "Subject: {$subject}";
$headers[] = "Return-Path: <$from>";
$headers[] = "X-Priority: 3";//1 = High, 3 = Normal, 5 = Low
$headers[] = "X-Mailer: PHP/" . phpversion();
mail($to, $subject, $message, implode("'r'n", $headers));