我正在制作一个提醒PHP脚本,每天会通过Cronjob调用一次,以告知客户有关smth的信息。
因此我正在使用PEAR Mail功能,并结合Mail_Mime。首先,脚本在mysql数据库中搜索用户。如果$num_rows > 0
,它正在创建一个新的Mail
对象和一个新的Mail_mime
对象(此帖子中包含的代码此时开始)。问题现在出现在while循环中。
确切地说:问题是
$mime->headers($headers, true);
作为文件。状态,第二个参数应该覆盖旧的标题。但是,所有外发邮件都会与第一个用户的标头($header['To']
)一起发送。
我真的对这件事感到疯狂......有什么建议吗?
(注意:但是,当为每个用户调用$mime = new Mail_mime()
时,它会发送正确的标头 - 但它应该只调用一次,然后覆盖旧标头)
代码:
// sql query and if num_rows > 0 ....
require_once('/usr/local/lib/php/Mail.php');
require_once('/usr/local/lib/php/Mail/mime.php');
ob_start();
require_once($inclPath.'/email/head.php');
$head = ob_get_clean();
ob_start();
require_once($inclPath.'/email/foot.php');
$foot = ob_get_clean();
$XY['mail']['params']['driver'] = 'smtp';
$XY['mail']['params']['host'] = 'smtp.XY.at';
$XY['mail']['params']['port'] = 25;
$mail =& Mail::factory('smtp', $XY['mail']['params']);
$headers = array();
$headers['From'] = 'XY <service@XY.at>';
$headers['Subject'] = '=?UTF-8?B?'.base64_encode('Subject').'?=';
$headers['Reply-To'] = 'XY <service@XY.at>';
ob_start();
require_once($inclPath.'/email/templates/files.mail.require-review.php');
$template = ob_get_clean();
$crfl = "\n";
$mime = new Mail_mime($crfl);
while($row = $r->fetch_assoc()){
$html = $head . $template . $foot;
$mime->setHTMLBody($html);
#$to = '=?UTF-8?B?'.base64_encode($row['firstname'].' '.$row['lastname']).'?= <'.$row['email'].'>'; // for testing purpose i'm sending all mails to webmaster@XY.at
$to = '=?UTF-8?B?'.base64_encode($row['firstname'].' '.$row['lastname']).'?= <webmaster@XY.at>';
$headers['To'] = $to; // Sets to in headers to a new
$body = $mime->get(array('head_charset' => 'UTF-8', 'text_charset' => 'UTF-8', 'html_charset' => 'UTF-8'));
$hdrs = $mime->headers($headers, true); // although the second parameters says true, the second, thrid, ... mail still includes the To-header form the first user
$sent = $mail->send($to, $hdrs, $body);
if (PEAR::isError($sent)) {
errlog('error while sending to user_id: '.$row['id']); // personal error function
} else {
// Write log file
}
}
答案 0 :(得分:1)
没有理由保留旧对象而不创建新对象。 正确使用OOP并创建新对象 - 您不知道它们如何在内部工作。