PHP电邮给客户

时间:2012-04-14 18:03:50

标签: php mysql sql email

我遇到了一些编程问题。当客户在咖啡馆网站的咖啡馆订购餐桌时,咖啡馆的所有者可以进入并批准或拒绝该订单。然后,订购董事会的客户必须收到一封电子邮件,说明该电子邮件已被接受或拒绝。

<?php

// Connect to server and select database.
mysql_connect("$host", "$username", "$password")or die("cannot connect");
mysql_select_db("$db_name")or die("cannot select DB");
mysql_query("SET NAMES utf8");
mysql_query("SET character_set_results='utf8&#8242;");

function escapeAddr($addr) {
    $check = preg_match('/(.*)<(.*)>/', $addr, $a);
    if ($check) $addr = '=?UTF-8?B?'.base64_encode($a[1]).'?= <'.$a[2].'>';
    return $addr;
}
function mail_utf8($to, $subject='no subject', $message='', $from='', $cc='', $bcc='') {
$to = $email;
$subject = "subject";
$message = "message" ;
$from = escapeAddr($from);
$header = 'From: '.$from.PHP_EOL
            . 'Return-Path: '.$from.PHP_EOL
            . 'Reply-To: '.$from.PHP_EOL
            . 'MIME-Version: 1.0'.PHP_EOL
            . 'Content-type: text/plain; charset=UTF-8'.PHP_EOL
            . 'X-Mailer: PHP/'.phpversion().PHP_EOL
            . 'Content-Transfer-Encoding: 8bit'.PHP_EOL;
    if ($cc!='') $header .= 'Cc: '.escapeAddr($cc).PHP_EOL;
    if ($bcc!='') $header .= 'Bcc: '.escapeAddr($bcc).PHP_EOL;
    $header .= PHP_EOL;
    return mail($to, '=?UTF-8?B?'.base64_encode($subject).'?=', $message, $header);
}

$g_id = ( isset( $_GET['id']) && is_numeric( $_GET['id']) ? (int)$_GET['id'] : FALSE);
if( !$g_id) {
    echo 'Error'; // ID not currect
}
else {
    $query = mysql_query("SELECT email FROM $tbl_name WHERE id=$g_id");
    $row = mysql_fetch_assoc($query);
    $email = $row['email'];

    if( mail_utf8($email, 'Table', 'message', 'no-reply@email.com')) {
        echo 'Accepted'; 
    }
    else
    {
        echo 'Error';
    }
}
?>

当然,所有者必须登录才能批准或拒绝订单。 由于它是您拒绝或批准的表单,但是<a href链接,我使用了路径accept.php?Id=

必须将电子邮件发送到与订单匹配的电子邮件。

2 个答案:

答案 0 :(得分:1)

在某些服务器中,依赖于设置,php邮件程序无法正常工作!也许你需要SMTP类来发送邮件。

答案 1 :(得分:0)

首先,你的第二个Mysql-Query中的Html-Character不存在。替换为' 第二,您可以尝试从邮件头中删除Content-Transfer-Encoding。 三,但微不足道的原因:是$ tbl_name设置?您确定$ from-variable中的地址是否具有正则表达式的正确格式?