我尝试开发一项新功能,系统可以在用户预订到期前一天向用户发送电子邮件。我写了一个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