Solved

My works exchange server is not recieving mails from the php mail() function

Posted on 2008-06-26
5
221 Views
Last Modified: 2013-12-12
I have developed a script - see attached - to monitor domains at the company i work for.

The problem is that the mail isn't hitting our exchange server. When its sent to my gmail account it works fine but it gets sent straight to the spam box.

I've been looking into a PHP mail class to get this working correctly but Im having problems getting that working - Is there something i am missing that is preventing this to recieve at our exchange

The below code runs a query and sends the results to my email using the mailing function in php
<?

mysql_connect("localhost","user","password"); 

mysql_select_db("dbname") or die( "Unable to select database"); 

 

  

$query=mysql_query("SELECT * FROM `domains` WHERE `exp_date` >= '0000-00-01' ORDER BY exp_date ASC LIMIT 25");
 

if(mysql_num_rows($query)){ 
 

      $to  = "my@email.com"; 

  

      $subject = "Expiry Notice";

   

      $from = "reminder@mydomain.co.uk";

      

      $msg = "<font face='MS Sans Serif'>

Hello,</font><BR><BR>";

  

      $msg .= "<font face='MS Sans Serif'>The next 25 domains to expire are the following:</font><BR><BR>";

      

while($row=mysql_fetch_array($query))

{    

 

  

   $domain_name=$row["domain_name"];

   $company_name=$row["company_name"];

   $simply_account=$row["simply_account"];

   $notes=$row["notes"];

   $id=$row["id"];

   $exp_date=$row["exp_date"];
 
 

      

if($query == TRUE)

    {
 
 

      $msg .= "<font face='MS Sans Serif'><b>$company_name</b>: $domain_name - $exp_date </font><BR>";  
 

}
 

}	

      

      $msg .= "<BR>";
 

      $msg .= "<font face='MS Sans Serif'>Domains Admin</font><BR><BR>";

 

       

  

      $headers = "MIME-Version: 1.0" . "\r\n";

  

      $headers .= "Content-type: text/html; charset=iso-8859-1" . "\r\n";

  

      $headers .= "From: reminder@mydomain.co.uk\r\nReply-To:reminder@mydomain.co.uk" . "\r\n";

 

       

 

      $mailsend = mail("$to","$subject","$msg","$headers");

  

      echo $mailsend ? "Email was sent :-)." : " Email sending failed :-(.";

}

?>

Open in new window

0
Comment
Question by:oku86
  • 3
  • 2
5 Comments
 
LVL 34

Expert Comment

by:Beverley Portlock
Comment Utility
It is likely that your work account's spam filter is stopping the email. It is therefore essential to construct the email in such a way that it does not trigger the spam filter.

I would start by stripping all HTML tags and just send the email through as a simple text email. Remove all the MIME stuff in $headers. It should be easy enough to alter the script you have already and just try it out and see what happens.

Having any HTML in an email ups the spam score.

Try the code below and see if it makes any difference
UNTESTED CODE!!!
 

<?

mysql_connect("localhost","user","password"); 

mysql_select_db("dbname") or die( "Unable to select database"); 

 

  

$query=mysql_query("SELECT * FROM `domains` WHERE `exp_date` >= '0000-00-01' ORDER BY exp_date ASC LIMIT 25");

 

if(mysql_num_rows($query)){ 

 

      $to  = "my@email.com"; 

  

      $subject = "Expiry Notice";

   

      $from = "reminder@mydomain.co.uk";

      
 

      $msg = "The next 25 domains to expire are the following:\r\n\r\n";

      

      while($row=mysql_fetch_array($query))

      {    

          $domain_name=$row["domain_name"];

          $company_name=$row["company_name"];

          $simply_account=$row["simply_account"];

          $notes=$row["notes"];

          $id=$row["id"];

          $exp_date=$row["exp_date"];

               

          if($query == TRUE)

               $msg .= "$company_name: $domain_name - $exp_date\r\n";

     

      }       

      

      $msg .= '\r\n';

      $msg .= "Domains Admin\r\n\r\n";
 

      $headers = "From: reminder@mydomain.co.uk\r\nReply-To:reminder@mydomain.co.uk" . "\r\n";

      

      $mailsend = mail("$to","$subject","$msg","$headers");

  

      echo $mailsend ? "Email was sent :-)." : " Email sending failed :-(.";

}

?>

Open in new window

0
 
LVL 1

Author Comment

by:oku86
Comment Utility
Still not reaching the exchange - i've been working along side the techie who runs our exchange server - hes allowed our email address to the whitelist in messagelabs and made several changes but nothing is coming though -

Just don't understand why its not working - we have just changed webhost to get the cron feature but is kind of pointless if the automated each cant reach us

This script worked fine on our last webhost
0
 
LVL 34

Expert Comment

by:Beverley Portlock
Comment Utility
Have you access to the webserver's mail logs? Can you find the mail transaction and verify that the mail was handed off to the Exchange server?
0
 
LVL 1

Author Comment

by:oku86
Comment Utility
From the webserver on my hosting? no i dont have but ill contact the host techie support to see whats happening

Ta

Dan
0
 
LVL 1

Accepted Solution

by:
oku86 earned 0 total points
Comment Utility
Ive managed to sort it at.
0

Featured Post

Complete Microsoft Windows PC® & Mac Backup

Backup and recovery solutions to protect all your PCs & Mac– on-premises or in remote locations. Acronis backs up entire PC or Mac with patented reliable disk imaging technology and you will be able to restore workstations to a new, dissimilar hardware in minutes.

Join & Write a Comment

Foreword In the years since this article was written, numerous hacking attacks have targeted password-protected web sites.  The storage of client passwords has become a subject of much discussion, some of it useful and some of it misguided.  Of cou…
Developers of all skill levels should learn to use current best practices when developing websites. However many developers, new and old, fall into the trap of using deprecated features because this is what so many tutorials and books tell them to u…
The viewer will learn how to look for a specific file type in a local or remote server directory using PHP.
This tutorial will teach you the core code needed to finalize the addition of a watermark to your image. The viewer will use a small PHP class to learn and create a watermark.

772 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

9 Experts available now in Live!

Get 1:1 Help Now