我尝试开发一项新功能,系统可以在用户预订到期前一天向用户发送电子邮件。我写了一个php脚本,每天早上用crontab触发php文件的执行。现在的问题是,如果我编译 php 文件,一切正常,并且电子邮件会发送给用户。当我检查邮件日志时,它告诉
to=<useremail@email.com>, ctladdr=<blablala> (0/0), delay=00:04:12, xdelay=00:04:12, mailer=esmtp, pri=120371, relay=XXXXXXX., stat=Sent (r3HMoisd031604 Message accepted for delivery)
但是如果我使用 crontab 执行相同的 php 文件,邮件将发送到服务器的根目录,而不是我在 php 文件中写的“useremail@email.com”。
to=<root@myserver.com>, ctladdr=<blablabla> (0/0), delay=00:00:00, xdelay=00:00:00, mailer=local, pri=30958, dsn=2.0.0, stat=Sent
它可能有什么问题?为什么 crontab 中的 php 文件不能按预期工作?任何人都可以帮忙吗?
我的 php 文件——“demo.php”
require_once "defaultincludes.inc";
global $tbl_entry, $tbl_users;
$current = mktime(date("H"),date("i"),0,date("m"),date("d"),date("Y"));
$start = $current + 12*3600;
$end = $current + 40*3600;
$query="SELECT U.email, U.fullname, E.name FROM $tbl_entry E, $tbl_users U "
." WHERE U.name = E.create_by "
." AND E.end_time >= $start "
." AND E.end_time <= $end ";
$result= sql_query($query);
$mail_list=array();
for ($i=0; ($row=sql_row_keyed($result,$i));$i++)
{
$temp=array();
$temp[]=$row['fullname'];
$temp[]=$row['email'];
$temp[]=$row['name'];
$mail_list[]=$temp;
}
for ($i=0; $i<count($mail_list); $i++) {
$to = $mail_list[$i][1];
$subject= "Reminder of ".$mail_list[$i][2];
$body = "Hi ".$mail_list[$i][0].",\n"
." Your reservation ".$mail_list[$i][2]." will expire in one day";
mail($to,$subject,$body);
}
crontab 文件——“reminder.txt”
30 7 * * * /var/www/html/qars-vm90/demo.php