首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >PHP模板:文件上传处理程序

PHP模板:文件上传处理程序
EN

Stack Overflow用户
提问于 2018-07-04 23:58:41
回答 1查看 340关注 0票数 2

我正在尝试为我一直在处理的常见PHP任务开发一些模板。其中之一是通用文件上传处理器。

到目前为止,我正在使用下面的可重用代码,它似乎工作得很好,没有任何明显的错误:

代码语言:javascript
复制
<?php

    if ( !isset($_POST['submit']) ) {
        goto page_content;}

    if ( $_FILES['file_upload']['error']===4 ) {
        echo 'No file uploaded';
        goto page_content;}

    if ( $_FILES['file_upload']['error']===1 || $_FILES['file_upload']['error']===2 ) {
        echo 'File exceeds maximum size limit';
        goto page_content;}

    if ( $_FILES['file_upload']['error']!==0 ) {
        echo 'Failed to upload the file';
        goto page_content;}

    if ( !is_uploaded_file($_FILES['file_upload']['tmp_name']) ) {
        echo 'Failed to upload the file';
        goto page_content;}

    require_once('imageResize.php');
    $err = imageResize($_FILES['file_upload']['tmp_name'], 'random.png' );
    if ( $err !== 0 ) {
        echo 'Invalid image format';
        goto page_content;}

    echo 'Image uploaded successfully';

    page_content:
?>
<form action="filename.php" method="POST" enctype="multipart/form-data">

    <input type="hidden" name="MAX_FILE_SIZE" value="1000000">
    <input type="file" name="file_upload" accept="image/*">
    <input type="submit" name="submit">

</form>

附加文件imageResize.php

代码语言:javascript
复制
<?php
    // image resize
    function imageResize($source, $target){

        $size = getimagesize($source);
        if ($size === false) {return 1;} // invalid image format

        $sourceImg = @imagecreatefromstring(@file_get_contents($source));
        if ($sourceImg === false) {return 2;} //invalid image format

        $width = imagesx($sourceImg);
        $height = imagesy($sourceImg);
        $sidelenght = min($width,$height);
        $targetImg = imagecreatetruecolor(100, 100);
        imagecopyresampled($targetImg, $sourceImg, 0, 0, ($width-$sidelenght)/2, ($height-$sidelenght)/2, 100, 100, $sidelenght, $sidelenght);
        imagedestroy($sourceImg);
        imagepng($targetImg, $target);
        imagedestroy($targetImg);

        return 0;           
    }
?>

这段代码的一些主要特征是:

  • 为上传过程中可能发生的最常见错误提供消息
  • 它允许客户端上传最大1Mb大小的图像文件
  • 将所有图像大小调整为标准100x100像素大小
  • 将所有图像保存为标准PNG格式

问题

  1. 这段代码安全吗?或者是否存在可被恶意客户端利用的漏洞?在这种情况下,如何解决呢?
  2. 为了避免几个嵌套的IF-THEN-ELSE条件(这可能会变得难以阅读),我目前使用GOTO (这可能会成为一种糟糕的控制结构实践)。有没有更好的选择?
  3. 有没有其他想法来改进它?
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-07-05 00:47:28

真的,把这段代码放到函数中(可能是一个类),而不是用return代替goto,这会让你更好地组织和分离需要分离的逻辑。

看看这个例子:

代码语言:javascript
复制
function upload_image($file)
{
  if( $err = check_error($file['error']) ) return $err;
  if( !is_uploaded_file($file['tmp_name']) ) return 'Failed to upload the file';
  $resize = imageResize($file['tmp_name'], 'random.png');
  if( $resize !== 0 )
  {
    return 'Invalid image format';
  }

  return true;
}

对于错误检查,请查看使用switch函数。它会更有条理(在我看来)。

我还会在一个单独的函数中检查数字上传错误,这样可以很容易地区分各个操作。

代码语言:javascript
复制
function check_error($err)
{
  if($err === 0)
  {
    return false; // no errors
  }
  $response = false;
  switch($err)
  {
    case 1:
    case 2:
      $response = 'File exceeds maximum size limit';
      break;
    case 4:
      $response = 'No file uploaded';
      break;
    default:
      $response = 'Unkown error';
  }
  return $response;
}

然后只需调用该函数并在顶部显示错误:

代码语言:javascript
复制
$upload = upload_image($_FILE['file_upload']);
if( $upload === true ):
  echo 'Image uploaded successfully!';
else:
  echo $upload;
?>
<form action="filename.php" method="POST" enctype="multipart/form-data">

  <input type="hidden" name="MAX_FILE_SIZE" value="1000000">
  <input type="file" name="file_upload" accept="image/*">
  <input type="submit" name="submit">

</form>
<?php endif; ?>
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/51177466

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档