duanan1228 2015-10-08 18:38
浏览 35
已采纳

仅允许图像上传器PHP脚本中的图像和PDF类型

I have a script that allows only 1 image to be uploaded which works fine.

But right now it allows any and all types to uploaded.

How do I only allow jpg, jpeg, gif, png & PDF files to be the only ones allowed to upload?

Here is part of my code.

<?php  

// make a note of the current working directory, relative to root.
$directory_self = str_replace(basename($_SERVER['PHP_SELF']), '', $_SERVER['PHP_SELF']);

// make a note of the directory that will recieve the uploaded files
$uploadsDirectory = $_SERVER['DOCUMENT_ROOT'] . $directory_self . 'uploaded_files/';

// make a note of the location of the upload form in case we need it
$uploadForm = 'http://' . $_SERVER['HTTP_HOST'] . $directory_self . 'multiple.upload.form.php';

// make a note of the location of the success page
$uploadSuccess = 'http://' . $_SERVER['HTTP_HOST'] . $directory_self . 'multiple.upload.success.php';

// name of the fieldname used for the file in the HTML form
$fieldname = 'file';

//echo'<pre>';print_r($_FILES);exit;

// Now let's deal with the uploaded files

// possible PHP upload errors
$errors = array(1 => 'php.ini max file size exceeded', 
                2 => 'html form max file size exceeded', 
                3 => 'file upload was only partial', 
                4 => 'no file was attached');

// check the upload form was actually submitted else print form
isset($_POST['submit'])
or error('the upload form is needed', $uploadForm);

// check if any files were uploaded and if 
// so store the active $_FILES array keys
$active_keys = array();
foreach($_FILES[$fieldname]['name'] as $key => $filename)
{
if(!empty($filename))
{
$active_keys[] = $key;
}
}

// check at least one file was uploaded
if (count($active_keys) < 1)
{ echo "<table border=\"0\" cellspacing=\"4\" cellpadding=\"4\"  style=\"border: 1px solid black; text-align: center; font-family: arial; font-size: 14px;\" width=\"600px\" align=\"center\">
<tr>
<td>
<font size=\"3\" color=\"red\"><strong><u>Upload Error</u></strong></font>
<br>
<br>
<b>You must upload one file.</b>
<br><br>
<a href=\"javascript: history.go(-1)\">Back to upload form</a>
<br>
</td>
</tr>
</table> <div style=\"display: none;\"> ";  }
//count($active_keys)
//or error('No files were uploaded', $uploadForm);

// check for standard uploading errors
foreach($active_keys as $key)
{
($_FILES[$fieldname]['error'][$key] == 0)
or error($_FILES[$fieldname]['tmp_name'][$key].': '.$errors[$_FILES[$fieldname]['error'][$key]], $uploadForm);
}

// check that the file we are working on really was an HTTP upload
foreach($active_keys as $key)
{
@is_uploaded_file($_FILES[$fieldname]['tmp_name'][$key])
or error($_FILES[$fieldname]['tmp_name'][$key].' not an HTTP upload', $uploadForm);
}

// make a unique filename for the uploaded file and check it is 
// not taken... if it is keep trying until we find a vacant one
foreach($active_keys as $key)
{
$now = time();
while(file_exists($uploadFilename[$key] = $uploadsDirectory.$now.'-'.$_FILES[$fieldname]['name'][$key]))
{
$now++;
}
}

// now let's move the file to its final and allocate it with the new filename
foreach($active_keys as $key)
{
@move_uploaded_file($_FILES[$fieldname]['tmp_name'][$key], $uploadFilename[$key])
or error('receiving directory insuffiecient permission', $uploadForm);
}

// If you got this far, everything has worked and the file has been successfully saved.
// We are now going to redirect the client to the success page.


if($_FILES['file']['error'] === UPLOAD_ERR_INI_SIZE) {
    // Handle the error
    echo 'Your file is too large.';
    die();
}
// make an error handler which will be used if the upload fails
function error($error, $location, $seconds = 5)
{
echo "<table border=\"0\" cellspacing=\"4\" cellpadding=\"4\"  style=\"border: 1px solid black; text-align: center; font-family: arial; font-size: 14px;\" width=\"600px\" align=\"center\">
<tr>
<td>
<font size=\"3\" color=\"red\"><strong><u>Upload Error</u></strong></font>
<br>
<br>
<!--<b>Your proof is not a supported filetype.<br>
Please upload an image (jpg, gif, png, bmp file) or PDF file.
<br>
<br>
or</b>
<br>
<br>-->
<b>Your File Size is bigger then the maximum allowed - 2 MB.<br>
Please upload a smaller file.</b>
<br><br>
<a href=\"javascript: history.go(-1)\">Back to upload form</a>
<br>
</td>
</tr>
</table> <div style=\"display: none;\">";
}
/*
{
header("Refresh: $seconds; URL=\"$location\"");
echo '<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN"'."
".
'"http://www.w3.org/TR/html4/strict.dtd">'."

".
'<html lang="en">'."
".
'<head>'."
".
'<meta http-equiv="content-type" content="text/html; charset=iso-8859-1">'."

".
'<link rel="stylesheet" type="text/css" href="stylesheet.css">'."

".
'<title>Upload error</title>'."

".
'</head>'."

".
'<body>'."

".
'<div id="Upload">'."

".
'<h1>Upload failure</h1>'."

".
'<p>An error has occured: '."

".
'<span class="red">' . $error . '...</span>'."

".
' The upload form is reloading</p>'."

".
' </div>'."

".
'</html>';
exit;
} // end error handler
*/

// < input id="file1" name="file[]" type="file" style="border: 1px solid white;">
//$fi= $_POST['file[]'];
//$fi = "(0)";

$fi = array($_FILES['file']['name']['0'],$_FILES['file']['name']['1'],$_FILES['file']['name']['2']);

====EDIT====

I was able to get it to ONLY allow images, but now how to I allow PDF's to be uploaded also?

I added this code to my script.

foreach($active_keys as $key)
{
@getimagesize($_FILES[$fieldname]['tmp_name'][$key])
or error($_FILES[$fieldname]['tmp_name'][$key].' not an image', $uploadForm);
}    
  • 写回答

2条回答 默认 最新

  • dtq81142 2015-10-09 16:14
    关注

    I was able to achieve this with the code below.

    $thefilename = $_FILES["file"]["name"][0];
    /* first, check for suffix
    (jpg, gif, png, bmp file) or PDF file */
    $thefilesuffix = substr($thefilename, -3);
    // echo "<p>".$thefilesuffix."</p><hr />";
    
    switch($thefilesuffix)
    {
    case "pdf": case "PDF":
    /* don't need to do anything special, 
    but notice the capitalized versions */
    break;
    
    case "jpg": case "gif": case "png": case "bmp": 
    case "JPG": case "GIF": case "PNG": case "BMP":
    //ALLOWS ONLY IMAGES TO BE UPLOADED
    foreach($active_keys as $key)
    {
    @getimagesize($_FILES[$fieldname]['tmp_name'][$key])
    or error($_FILES[$fieldname]['tmp_name'][$key].' not an image', $uploadForm);
    }   
    //ALLOWS ONLY IMAGES TO BE UPLOADED
    break;
    
    default:
    echo "<table border=\"0\" cellspacing=\"4\" cellpadding=\"4\"  style=\"border: 1px solid black; text-align: center; font-family: arial; font-size: 14px;\" width=\"600px\" align=\"center\">
    <tr>
    <td>
    <font size=\"3\" color=\"red\"><strong><u>Upload Error</u></strong></font>
    <br>
    <br>
    <b>Your proof must be an an image (jpg, gif, png, bmp file) or PDF file.<br>
    Please upload a different file.</b>
    <br>
    <br>
    <a href=\"javascript: history.go(-1)\">Back to upload form</a>
    <br>
    </td>
    </tr>
    </table> <div style=\"display: none;\">"; exit;
    break;
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 drone 推送镜像时候 purge: true 推送完毕后没有删除对应的镜像,手动拷贝到服务器执行结果正确在样才能让指令自动执行成功删除对应镜像,如何解决?
  • ¥15 求daily translation(DT)偏差订正方法的代码
  • ¥15 js调用html页面需要隐藏某个按钮
  • ¥15 ads仿真结果在圆图上是怎么读数的
  • ¥20 Cotex M3的调试和程序执行方式是什么样的?
  • ¥20 java项目连接sqlserver时报ssl相关错误
  • ¥15 一道python难题3
  • ¥15 牛顿斯科特系数表表示
  • ¥15 arduino 步进电机
  • ¥20 程序进入HardFault_Handler