日期:2014-05-17  浏览次数:20643 次

高手!!高手!!请进来看一下!!有关复杂邮件的一个功能!!!
折腾一周没做出来的一个东东,今天周末加班还是没有战果,初次接触程序啊,还望高手多多指点!!!!在此先谢过!!!

需求:
做一个合同模块,分多段提醒,我现在只做了两段提醒。

即:
只要检测到sdate,edate 有与当前系统时间(2008-7-19)时间相同的都得那行邮件地址发送一份邮件.

数据库设置:
sdate edate email name
2008-7-11 2008-7-19 adfd@aa.com adfd
2008-7-15 2008-7-19 bbcc@aa.com bbcc

2008-7-19 2008-7-22 xxbb@aa.com xxbb
2008-7-19 2008-7-28 ccbb@aa.com ccbb



基本实现思路:

我现在用了一个phpmailer的类来做。(环境是:linux+apache+php+mysql)

写了一个cron.php的文件(如下:),用crontab每天刷新一次cron.php页面

判断当当前系统时间与2008-7-19一致,如果是一致就发邮件
照上面数据的数据,检测到sdate有二条2008-7-19,edate有二条2008-7-19,就得发四个邮件提醒这四个用户。


现在我的程序出现问题: 就是每次只会去取其中一条记录,而且只会对这一条记录发邮件,而其它三条相同的时间,就没办法达到提醒功能;

非常急切,请大家帮忙!!!非常感谢感谢!!



//cron.php的文件如下:

<?php
date_default_timezone_set('Asia/Shanghai'); 
$datesy=date("Y-m-d"); //当前系统时间

//$format="<tr><td>%s</td><td>%s</td><td>%s</td><td>%s</td><td>%s</td><td>%s</td>"; 

$db=mysql_connect('localhost','root','');
mysql_select_db('test',$db);
$sql="select sdate,edate,email,name from testmail"; //sdate 与edate字段分别对应数据库中的两段时间
mysql_query("set names gb2312"); 
$result=mysql_query($sql,$db);

while ($row = mysql_fetch_array($result))  
  {
   
   
  printf ($format,$row[0],$row[1],$row[2],$row[3],$row[4],$row[5]); 


if($datesy==$row[0] || datesy==$row[1]) //目前是:如果定点刷新页面,程序只会去检测$row[1] 也就是edate时间,只会取一个而发送邮件,如果edate有2条或更多为2008--7-19的时间,都不会发邮件。我的目的是要:如果sdate ,date 哪怕是一百行数据,只要是与当前时间一致,都要发邮件。
{

require("phpmailer/class.phpmailer.php");
   
$mail = new PHPMailer();
$address=$row[1];

$mail->IsSMTP(); // set mailer to use SMTP
$mail->Host = "mail.aaa.com.cn"; // specify main and backup server
$mail->SMTPAuth = true; // turn on SMTP authentication
$mail->Username = "Josh"; // SMTP username
$mail->Password = "password"; // SMTP password

$mail->From = "Josh@aaa.com.cn";
$mail->FromName = "Mailer";
$mail->AddAddress("$address", "Josh Adams");
$mail->AddAddress("xx@bbb.com.cn"); // name is optional
$mail->AddReplyTo("xx@bbb.com.cn", "Information");

$mail->WordWrap = 50; // set word wrap to 50 characters
$mail->AddAttachment("/var/tmp/file.tar.gz"); // add attachments
$mail->AddAttachment("/tmp/image.jpg", "new.jpg"); // optional name
$mail->IsHTML(true); // set email format to HTML
$name="$row[2]";
$mail->Subject ="$name 到期了";
$mail->Body = "This is the HTML message body <b>in bold!</b>";
$mail->AltBody = "This is the body in plain text for non-HTML mail clients";

if(!$mail->Send())
{
  echo "Message could not be sent. <p>";
  echo "Mailer Error: " . $mail->ErrorInfo;
  exit;
}

echo "Message has been sent";
}
   
  // }

else 
{
echo "不成功";
}

  }


mysql_close(); 



?>





------解决方案--------------------