Jump to content

Recommended Posts

I am busy working on a 'profile pic' feature for my site,

 

so far it seems to be working ok with this:

 

if (isset($_POST[upload_pic]))
{$file_name = $_FILES[pic][name];
   $file_type = $_FILES[pic][type];
   $file_tmp = $_FILES[pic][tmp_name];
   $file_size = $_FILES[pic][size];

   if (eregi(".jpg", $filename) || ereg(".jpeg", $filename))
    {copy($file_tmp, "../file_uploads/profile_pic-$user-$user_id.jpeg");
    }
  else
   {echo "File is NOT a jpeg format photo!";
   }		
}

 

Most importantly, is this a secure method for uploading files?

 

Firstly, should I be using the 'copy()' function or the 'move_uploaded_file()'?

 

Secondly, if someone had a file virus.exe and renamed it to virus.jpeg, uploaded it to my site, is there anyway he can run that file as a .exe?

 

Thirdly, how do I make a photo id counter example (for the purpose of multiple pics):

profile_pic-george-1-1.jpeg

profile_pic-george-1-2.jpeg

profile_pic-george-1-3.jpeg

profile_pic-george-1-4.jpeg ?

Using the mysql database seems to be a waste of resources for such a lil thing?

Link to comment
https://forums.phpfreaks.com/topic/162159-uploading-files-with-php-few-questions/
Share on other sites

2. No not possible. Any files uploaded to the server cannot be executed, unless they find a security hole in your site which allowed them to run malicious code.

 

?... So then why do I often read that you should 'prevent' users from uploading malicious files?...

Ok, that copy I gave doesn't seem to work....

I worked on it abit:

if (isset($_POST[upload_pic]))
{$file_name = $_FILES[pic][name];
   $file_type = $_FILES[pic][type];
   $file_tmp = $_FILES[pic][tmp_name];
   $file_size = $_FILES[pic][size];
   
   if (eregi (" .jpg", $file_name) || eregi(" .jpeg", $file_name)
       && eregi("image", $file_type))
    {move_uploaded_file($file_tmp, "../file_uploads/profile_pic-$user-$user_id.jpeg");
    }
  else
   {echo "<p class='error'>File is NOT a photo in jpeg format!</p>";
   }
   //I only echo out this for me
   echo "<p class='smallheading'>File name: $file_name
            <br/>
		File type: $file_type
		<br/>
		File location: $file_tmp
		<br/>
		File size: $file_size"; 

// When someone loads a users profile, if the 'profile_pic' value is not equal
// to 1, it must show the defualt picture
$sql_u_profilepic = "UPDATE users_profile SET profile_pic='1'
                             WHERE user_id='$user_id'";
$mq_u_profilepic = mysqli_query($mysqli_con, $sql_u_profilepic);
}

 

Two questions though, when a file bigger than the $_POST[max_file_size] is uploaded, the $_FILES[pic] becomes zero, so I can't make a

<?php]
$max_size = 500,000; //0.5 mb
if ($_FILES[pic][size] > $max_size)
{die;
else
{//copy the file
}
?>

 

As it will always be less than the $max_size...

 

Secondly,

eregi(" .jpeg", $file_name)

Will allow any file containing " .jpeg" (so 'virus bad .jpeg .exe' will be allowed). How do I change it so that ".jpeg" MUST BE AT THE END of the file name?...

 

 

Once again, thanks guys in advance!

This thread is more than a year old. Please don't revive it unless you have something important to add.

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.

Guest
Reply to this topic...

×   Pasted as rich text.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

×
×
  • Create New...

Important Information

We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue.