Solved

Conflict between PhpMailer and phpmail

Posted on 2008-10-17
5
469 Views
Last Modified: 2009-04-02
Hi Am using the following code to send two different emails with the same form.  am using phpmailer to send the mail with attachment and phpmail to send without the attachment to two different recepients.

This code works fine when the size of the attachment is smaill like 3-10kb but if the size is a bigger one something like 245kb only the first mail goes through and second mail doesn't.

Please let me know what is wrong here.
$uploaddir = 'c:\\ABC\\';

$uploadfile = $uploaddir . basename($_FILES['file']['name']);

move_uploaded_file($_FILES['file']['tmp_name'], $uploadfile); 

 

$mail = new PHPMailer();

 

$mail->IsSMTP();                      

$mail->Host = "X.X.X.X"; 

 

 

$mail->From = $_POST['email'];

$mail->FromName = "Submissioin";

$mail->AddAddress("abc@abc.com");                 

                              

$mail->AddAttachment($uploadfile); 

$mail->IsHTML(true);        

$mail->Subject = "Submission Form";

 

$mail_body = "Test mail";

$mail->Body    = $mail_body;

 

 

if(!$mail->Send())

{

   echo "Message could not be sent. <p>";

   echo "Mailer Error: " . $mail->ErrorInfo;

   exit;

}

else

{

$mail->ClearAddresses();

$mail->ClearAttachments();

 

//sending email using phpmailer===============================================================

$Name =  $_POST['fName'] . ' ' . $_POST['Lname']; 

$email = $_POST['email']; 

$recipient = "xyz@xyz.com"; 

$mail_body = "Attachment recieved";                       

$subject = "Submission Form"; //subject 

$header = "From: ". $Name . " <" . $email . ">\r\n"; //optional headerfields  

$mail_body = strip_tags( preg_replace('#<br\s*/?>#i',"\n",$mail_body) );

mail($recipient, $subject, $mail_body, $header); 

 

//======================================================================

 

 

header("Location: http://somewhere.ca.com/partnerescalation/reqkd.php");

exit();}

Open in new window

0
Comment
Question by:Shiva_Kumar
  • 2
5 Comments
 
LVL 10

Accepted Solution

by:
wildzero earned 500 total points
ID: 22749468
Hi there,

This block of code here

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

Means that it's only ever going to send 1 email. It will try and do PHPMailer, and only if that fails it will use the PHP Mail. If you want it to always send two emails then you can use this. The code below will not stop on errors.

You should also check and make your capitilization consistant
$Name =  $_POST['fName'] . ' ' . $_POST['Lname'];
is it fName or Fname? Lname or lName


$uploaddir = 'c:\\ABC\\';

$uploadfile = $uploaddir . basename($_FILES['file']['name']);

move_uploaded_file($_FILES['file']['tmp_name'], $uploadfile); 

 

$mail = new PHPMailer();

 

$mail->IsSMTP();                      

$mail->Host = "X.X.X.X"; 

 

 

$mail->From = $_POST['email'];

$mail->FromName = "Submissioin";

$mail->AddAddress("abc@abc.com");                 

                              

$mail->AddAttachment($uploadfile); 

$mail->IsHTML(true);        

$mail->Subject = "Submission Form";

 

$mail_body = "Test mail";

$mail->Body    = $mail_body;

 

$mail->Send();

$mail->ClearAddresses();

$mail->ClearAttachments();

 

//sending email using phpmailer=================================

$Name =  $_POST['fName'] . ' ' . $_POST['Lname']; 

$email = $_POST['email']; 

$recipient = "xyz@xyz.com"; 

$mail_body = "Attachment recieved";                       

$subject = "Submission Form"; //subject 

$header = "From: ". $Name . " <" . $email . ">\r\n"; //optional headerfields  

$mail_body = strip_tags( preg_replace('#<br\s*/?>#i',"\n",$mail_body) );

mail($recipient, $subject, $mail_body, $header); 

 

//======================================================================

 

 

header("Location: http://somewhere.ca.com/partnerescalation/reqkd.php");

exit();

Open in new window

0
 
LVL 25

Expert Comment

by:Squinky
ID: 22749540
> Means that it's only ever going to send 1 email. It will try and do PHPMailer, and only if that fails it will use the PHP Mail.

That's not true. There's a ! in that if that means it will only exit if it fails to send.

It's a complete mystery to me why you'd use PHPMailer to send the first one but not the second. Using mail() directly is generally just asking for trouble, as you're seeing. I'm not going to debug that code because the right fix is to use PHPMailer to send that as well.
0
 

Author Comment

by:Shiva_Kumar
ID: 22778154
Thank you, it worked
0
 
LVL 25

Expert Comment

by:Squinky
ID: 22778194
What worked? In the selected answer, the logic is completely wrong and it gets around the problem of there being an error by removing the error checking!
0

Featured Post

How your wiki can always stay up-to-date

Quip doubles as a “living” wiki and a project management tool that evolves with your organization. As you finish projects in Quip, the work remains, easily accessible to all team members, new and old.
- Increase transparency
- Onboard new hires faster
- Access from mobile/offline

Join & Write a Comment

These days socially coordinated efforts have turned into a critical requirement for enterprises.
Nothing in an HTTP request can be trusted, including HTTP headers and form data.  A form token is a tool that can be used to guard against request forgeries (CSRF).  This article shows an improved approach to form tokens, making it more difficult to…
The viewer will learn how to count occurrences of each item in an array.
The viewer will learn how to create and use a small PHP class to apply a watermark to an image. This video shows the viewer the setup for the PHP watermark as well as important coding language. Continue to Part 2 to learn the core code used in creat…

705 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

16 Experts available now in Live!

Get 1:1 Help Now