mallen Posted September 21, 2008 Share Posted September 21, 2008 I have this script that allows a user to email an attachment. I'm trying to check the file size and type of file. See the section I added in the middle. Keeps giving e the message "wrong file type" and won't send the email. <?php if ($_SERVER['REQUEST_METHOD']=="POST"){ // we'll begin by assigning the To address and message subject $to="[email protected]"; $subject="E-mail with attachment"; // get the sender's name and email address // we'll just plug them a variable to be used later $from = stripslashes($_POST['fromname'])."<".stripslashes($_POST['fromemail']).">"; // generate a random string to be used as the boundary marker $mime_boundary="==Multipart_Boundary_x".md5(mt_rand())."x"; // store the file information to variables for easier access $tmp_name = $_FILES['filename']['tmp_name']; $type = $_FILES['filename']['type']; $name = $_FILES['filename']['name']; $size = $_FILES['filename']['size']; // here we'll hard code a text message // again, in reality, you'll normally get this from the form submission $message = "Here is your file: $name"; // if the upload succeded, the file will exist if (file_exists($tmp_name)){ // check to make sure that it is an uploaded file and not a system file if(is_uploaded_file($tmp_name)){ // open the file for a binary read $file = fopen($tmp_name,'rb'); // read the file content into a variable $data = fread($file,filesize($tmp_name)); // close the file fclose($file); // now we encode it and split it into acceptable length lines $data = chunk_split(base64_encode($data)); } // now we'll build the message headers $headers = "From: $from\r\n" . "MIME-Version: 1.0\r\n" . "Content-Type: multipart/mixed;\r\n" . " boundary=\"{$mime_boundary}\""; // next, we'll build the message body // note that we insert two dashes in front of the // MIME boundary when we use it $message = "This is a multi-part message in MIME format.\n\n" . "--{$mime_boundary}\n" . "Content-Type: text/plain; charset=\"iso-8859-1\"\n" . "Content-Transfer-Encoding: 7bit\n\n" . $message . "\n\n"; // now we'll insert a boundary to indicate we're starting the attachment // we have to specify the content type, file name, and disposition as // an attachment, then add the file content and set another boundary to // indicate that the end of the file has been reached $message .= "--{$mime_boundary}\n" . "Content-Type: {$type};\n" . " name=\"{$name}\"\n" . //"Content-Disposition: attachment;\n" . //" filename=\"{$fileatt_name}\"\n" . "Content-Transfer-Encoding: base64\n\n" . $data . "\n\n" . "--{$mime_boundary}--\n"; //Added content here****************************************** define ("MAX_SIZE","50"); function getExtension($str) { $i = strrpos($str,"."); if (!$i) { return ""; } $l = strlen($str) - $i; $type = substr($str,$i+1,$l); return $ext; } $errors=0; $filename = stripslashes($_FILES['image']['name']); $type = getExtension($name); $type = strtolower($extension); if (($type != "jpg") && ($type != "jpeg") && ($type != "png") && ($type != "pdf") && ($type != "dwg") && ($type != "gif")) { echo 'Unknown file extension! Only .gif, .jpg, .png, pdf and dwg and files are allowed to be uploaded </a>.'; $errors=1; die (); } $size=filesize($_FILES['image']['tmp_name']); if ($size > MAX_SIZE*1024) { echo 'You have exceeded the size limit!'; $errors=1; die (); } //End Added content********************************** // now we just send the message if (@mail($to, $subject, $message, $headers)) echo "Message Sent"; else echo "Failed to send"; } } else { ?> <p>Send an e-mail with an attachment:</p> <form action="<?php echo $_SERVER['PHP_SELF']; ?>" method="post" enctype="multipart/form-data" name="form1"> <p>From name: <input type="text" name="fromname"></p> <p>From e-mail: <input type="text" name="fromemail"></p> <p>File: <input type="file" name="filename"></p> <p><input type="submit" name="Submit" value="Submit"></p> </form> <?php } ?> Link to comment https://forums.phpfreaks.com/topic/125135-email-form-and-attachments/ Share on other sites More sharing options...
Adam Posted September 21, 2008 Share Posted September 21, 2008 Does it say "wrong file type" .. or does it say .. "Unknown file extension! Only .gif, .jpg, .png, pdf and dwg and files are allowed to be uploaded" ?? Have you double checked the function getExtension is returning the right value? Adam Link to comment https://forums.phpfreaks.com/topic/125135-email-form-and-attachments/#findComment-646777 Share on other sites More sharing options...
mallen Posted September 21, 2008 Author Share Posted September 21, 2008 Unknown file extension! Only .gif, .jpg, .png, pdf and dwg and files are allowed to be uploaded How would I know its returning the right value? Link to comment https://forums.phpfreaks.com/topic/125135-email-form-and-attachments/#findComment-646780 Share on other sites More sharing options...
.josh Posted September 21, 2008 Share Posted September 21, 2008 by echoing it out and seeing what it's holding. Link to comment https://forums.phpfreaks.com/topic/125135-email-form-and-attachments/#findComment-646781 Share on other sites More sharing options...
mallen Posted September 21, 2008 Author Share Posted September 21, 2008 I put echo $type; and tried uploading a Word doc and it returned : application/msword Link to comment https://forums.phpfreaks.com/topic/125135-email-form-and-attachments/#findComment-646782 Share on other sites More sharing options...
Adam Posted September 21, 2008 Share Posted September 21, 2008 Well just cut and paste the function into a new file and test it out, eg: <?php function getExtension($str) { $i = strrpos($str,"."); if (!$i) { return ""; } $l = strlen($str) - $i; $type = substr($str,$i+1,$l); return $ext; } print getExtension('testfile.jpg'); ?> if it works properly should return "jpg", but possibly could be returning ".jpg" ?? You could use something MUCH simpler like: function file_extension($filename) { $path_info = pathinfo($filename); return $path_info['extension']; } Adam Link to comment https://forums.phpfreaks.com/topic/125135-email-form-and-attachments/#findComment-646783 Share on other sites More sharing options...
Adam Posted September 21, 2008 Share Posted September 21, 2008 Ignore first half of last post, but there's your problem... Adam Link to comment https://forums.phpfreaks.com/topic/125135-email-form-and-attachments/#findComment-646784 Share on other sites More sharing options...
.josh Posted September 21, 2008 Share Posted September 21, 2008 anyways, in your function, return $ext; should be return $type; Link to comment https://forums.phpfreaks.com/topic/125135-email-form-and-attachments/#findComment-646785 Share on other sites More sharing options...
mallen Posted September 21, 2008 Author Share Posted September 21, 2008 Now I have define ("MAX_SIZE","50"); function file_extension($filename) { $path_info = pathinfo($filename); return $path_info['extension']; } $errors=0; $filename = stripslashes($_FILES['image']['name']); $type = file_extension($name); $type = strtolower($extension); if (($type != "jpg") && ($type != "jpeg") && ($type != "png") && ($type != "pdf") && ($type != "dwg") && ($type != "gif")) { echo 'Unknown file extension! Only .gif, .jpg, .png, pdf and dwg and files are allowed to be uploaded </a>.'; $errors=1; die (); } $size=filesize($_FILES['image']['tmp_name']); if ($size > MAX_SIZE*1024) { echo 'You have exceeded the size limit!'; $errors=1; die (); } And I still get "Unknown file extension! Only .gif, .jpg, .png, pdf and dwg and files are allowed to be uploaded ." Link to comment https://forums.phpfreaks.com/topic/125135-email-form-and-attachments/#findComment-646789 Share on other sites More sharing options...
Adam Posted September 21, 2008 Share Posted September 21, 2008 double check $filename 's what its supposed to be .. Link to comment https://forums.phpfreaks.com/topic/125135-email-form-and-attachments/#findComment-646791 Share on other sites More sharing options...
redarrow Posted September 21, 2008 Share Posted September 21, 2008 if ($size > MAX_SIZE*1024) { correct..... $size = $_FILES['filename']['size']; Link to comment https://forums.phpfreaks.com/topic/125135-email-form-and-attachments/#findComment-646797 Share on other sites More sharing options...
mallen Posted September 21, 2008 Author Share Posted September 21, 2008 double check $filename 's what its supposed to be .. Not sure what you mean here. ??? Link to comment https://forums.phpfreaks.com/topic/125135-email-form-and-attachments/#findComment-646804 Share on other sites More sharing options...
.josh Posted September 21, 2008 Share Posted September 21, 2008 by echoing it out and seeing what it's holding. Link to comment https://forums.phpfreaks.com/topic/125135-email-form-and-attachments/#findComment-646817 Share on other sites More sharing options...
mallen Posted September 21, 2008 Author Share Posted September 21, 2008 by echoing it out and seeing what it's holding. I echoed $filename and it didn't return anything. ??? Link to comment https://forums.phpfreaks.com/topic/125135-email-form-and-attachments/#findComment-646987 Share on other sites More sharing options...
mallen Posted September 21, 2008 Author Share Posted September 21, 2008 return $path_info['extension']; I don't understand this part. Where is it getting 'extension' ? Link to comment https://forums.phpfreaks.com/topic/125135-email-form-and-attachments/#findComment-647287 Share on other sites More sharing options...
Adam Posted September 21, 2008 Share Posted September 21, 2008 The function "pathinfo" - http://uk2.php.net/pathinfo - returns an array of information about a filepath .. are you using PHP4? Link to comment https://forums.phpfreaks.com/topic/125135-email-form-and-attachments/#findComment-647307 Share on other sites More sharing options...
mallen Posted September 22, 2008 Author Share Posted September 22, 2008 Thanks for the reply. I am using PHP 5. Anything you can help me get this working is appreciated. Link to comment https://forums.phpfreaks.com/topic/125135-email-form-and-attachments/#findComment-647338 Share on other sites More sharing options...
Adam Posted September 22, 2008 Share Posted September 22, 2008 $filename = stripslashes($_FILES['image']['name']); $type = getExtension($name); $type = strtolower($extension); Problem is here i think, should be: $filename = stripslashes($_FILES['filename']['name']); $type = strtolower( getExtension( $filename)); Link to comment https://forums.phpfreaks.com/topic/125135-email-form-and-attachments/#findComment-647344 Share on other sites More sharing options...
Adam Posted September 22, 2008 Share Posted September 22, 2008 You're using $_FILES['image'] and $_FILES['filename'] when it should be (as it is on the form) $_FILES['filename'] .. Link to comment https://forums.phpfreaks.com/topic/125135-email-form-and-attachments/#findComment-647346 Share on other sites More sharing options...
mallen Posted September 22, 2008 Author Share Posted September 22, 2008 Now I get: Fatal error: Call to undefined function getExtension() in ..... Link to comment https://forums.phpfreaks.com/topic/125135-email-form-and-attachments/#findComment-647351 Share on other sites More sharing options...
Adam Posted September 22, 2008 Share Posted September 22, 2008 oh yeah you changed it to: function file_extension($filename) { $path_info = pathinfo($filename); return $path_info['extension']; } ... so needs to be: $filename = stripslashes($_FILES['filename']['name']); $type = strtolower( file_extension( $filename)); Link to comment https://forums.phpfreaks.com/topic/125135-email-form-and-attachments/#findComment-647356 Share on other sites More sharing options...
mallen Posted September 22, 2008 Author Share Posted September 22, 2008 Ok I am getting close. Now I have this <?php if ($_SERVER['REQUEST_METHOD']=="POST"){ // we'll begin by assigning the To address and message subject $to="[email protected]"; $subject="E-mail with attachment"; // get the sender's name and email address // we'll just plug them a variable to be used later $from = stripslashes($_POST['fromname'])."<".stripslashes($_POST['fromemail']).">"; // generate a random string to be used as the boundary marker $mime_boundary="==Multipart_Boundary_x".md5(mt_rand())."x"; // store the file information to variables for easier access $tmp_name = $_FILES['filename']['tmp_name']; $type = $_FILES['filename']['type']; $name = $_FILES['filename']['name']; $size = $_FILES['filename']['size']; // here we'll hard code a text message // again, in reality, you'll normally get this from the form submission $message = "Here is your file: $name"; // if the upload succeded, the file will exist if (file_exists($tmp_name)){ // check to make sure that it is an uploaded file and not a system file if(is_uploaded_file($tmp_name)){ // open the file for a binary read $file = fopen($tmp_name,'rb'); // read the file content into a variable $data = fread($file,filesize($tmp_name)); // close the file fclose($file); // now we encode it and split it into acceptable length lines $data = chunk_split(base64_encode($data)); } // now we'll build the message headers $headers = "From: $from\r\n" . "MIME-Version: 1.0\r\n" . "Content-Type: multipart/mixed;\r\n" . " boundary=\"{$mime_boundary}\""; // next, we'll build the message body // note that we insert two dashes in front of the // MIME boundary when we use it $message = "This is a multi-part message in MIME format.\n\n" . "--{$mime_boundary}\n" . "Content-Type: text/plain; charset=\"iso-8859-1\"\n" . "Content-Transfer-Encoding: 7bit\n\n" . $message . "\n\n"; // now we'll insert a boundary to indicate we're starting the attachment // we have to specify the content type, file name, and disposition as // an attachment, then add the file content and set another boundary to // indicate that the end of the file has been reached $message .= "--{$mime_boundary}\n" . "Content-Type: {$type};\n" . " name=\"{$name}\"\n" . //"Content-Disposition: attachment;\n" . //" filename=\"{$fileatt_name}\"\n" . "Content-Transfer-Encoding: base64\n\n" . $data . "\n\n" . "--{$mime_boundary}--\n"; define ("MAX_SIZE","50"); function file_extension($filename) { $path_info = pathinfo($filename); return $path_info['extension']; } $errors=0; $filename = stripslashes($_FILES['filename']['name']); $type = strtolower( file_extension( $filename)); if (($type != "jpg") && ($type != "jpeg") && ($type != "png") && ($type != "pdf") && ($type != "dwg") && ($type != "gif")) { echo 'Unknown file extension. Only .gif, .jpg, .png, pdf and dwg and files are allowed to be uploaded </a>.'; echo $path_parts['extension'], "\n"; $errors=1; die (); } $size=filesize($_FILES['image']['tmp_name']); if $size = $_FILES['filename']['size']; { echo 'You have exceeded the size limit!'; $errors=1; die (); } // now we just send the message if (@mail($to, $subject, $message, $headers)) echo "Message Sent"; else echo "Failed to send"; } } else { ?> <p>Send an e-mail with an attachment:</p> <form action="<?php echo $_SERVER['PHP_SELF']; ?>" method="post" enctype="multipart/form-data" name="form1"> <p>From name: <input type="text" name="fromname"></p> <p>From e-mail: <input type="text" name="fromemail"></p> <p>File: <input type="file" name="filename"></p> <p><input type="submit" name="Submit" value="Submit"></p> </form> <?php } ?> And I get this error Parse error: syntax error, unexpected T_VARIABLE, expecting '(' in .....on line 109 Which is this line if $size = $_FILES['filename']['size']; Link to comment https://forums.phpfreaks.com/topic/125135-email-form-and-attachments/#findComment-647361 Share on other sites More sharing options...
Adam Posted September 22, 2008 Share Posted September 22, 2008 if's need brackets.. if (something == something) { ... } should be: if ($size == $_FILES['filename']['size']) Link to comment https://forums.phpfreaks.com/topic/125135-email-form-and-attachments/#findComment-647362 Share on other sites More sharing options...
mallen Posted September 22, 2008 Author Share Posted September 22, 2008 Ok got it working I think. Now I need to set the file size properly. I want to set a limit of 1MB. Link to comment https://forums.phpfreaks.com/topic/125135-email-form-and-attachments/#findComment-647366 Share on other sites More sharing options...
Adam Posted September 22, 2008 Share Posted September 22, 2008 Don't understand what you're trying to do there though... $size=filesize($_FILES['image']['tmp_name']); if ($size == $_FILES['filename']['size']); { echo 'You have exceeded the size limit!'; echo $size; $errors=1; die (); } $_FILES['image'] .. isn't actually used on the form, not sure why you have lots of references to it? But you need to set a size limit yourself. with that you're basically setting the filesize limit to equal the filesize of a file i'm not even sure exists; filesize($_FILES['image']['tmp_name']) ...? should look something more like: if ($_FILES['filename']['size'] >= 1048576) { echo 'You have exceeded the size limit of 1Mb!'; echo ' Actual size: '.$_FILES['filename']['size']; $errors=1; die (); } Link to comment https://forums.phpfreaks.com/topic/125135-email-form-and-attachments/#findComment-647372 Share on other sites More sharing options...
Recommended Posts
Archived
This topic is now archived and is closed to further replies.