我尝试开发一项新功能,系统可以在预订到期前一天向用户发送电子邮件。 我写了一个php脚本,并使用crontab每天早上触发php文件的执行。 现在的问题是,如果我编译php文件,一切正常,电子邮件将发送给用户。当我检查maillog时,它告诉
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
可能是什么问题?为什么php文件无法按预期从crontab工作?有人可以帮忙吗?
我的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
答案 0 :(得分:0)
没有足够的信息来回答您的问题。 php脚本从哪里获取电子邮件地址?用户通常运行的是什么,以及用户从cron运行的用户是什么?
答案 1 :(得分:0)
/var/www/html/qars-vm90/demo.php
仅在脚本标记为可执行时才有效。另外你需要在文件顶部放一个shebang来告诉shell如何处理文件(如果用perl,php,python等执行它的话)
我怀疑发送的电子邮件是来自cron的错误消息,说该文件不可执行。如果您以root用户身份登录,则应该能够阅读该消息。
最简单的更改可能是将您的crontab更改为
30 7 * * * php /var/www/html/qars-vm90/demo.php
还值得记住的是,cron的环境通常与命令行(登录shell和所有内容)略有不同