douduoquan2824 2015-10-03 23:10
浏览 54
已采纳

将上传白名单更改为黑名单

Instead of $allowed, I want to create $deny; instead of a whitelist, I want to make a blacklist. Mainly because I want to accept all files, except for exe, com, or whichever I choose.

<?php

// A list of permitted file extensions
$allowed = array('jpg','txt');

if(isset($_FILES['upl']) && $_FILES['upl']['error'] == 0){

    $extension = pathinfo($_FILES['upl']['name'], PATHINFO_EXTENSION);

    if(!in_array(strtolower($extension), $allowed)){
        echo '{"status":"error"}';
        exit;
    }

    if(move_uploaded_file($_FILES['upl']['tmp_name'], 'uploads/'.$_FILES['upl']['name'])){
        echo '{"status":"success"}';
        exit;
    }
}

echo '{"status":"error"}';
exit;
  • 写回答

2条回答 默认 最新

  • douliao5942 2015-10-03 23:15
    关注

    You want like this, i guess;

    <?php
    
    // A list of permitted file extensions
    $denied = array('exe','com');
    
    if(isset($_FILES['upl']) && $_FILES['upl']['error'] == 0){
    
        $extension = pathinfo($_FILES['upl']['name'], PATHINFO_EXTENSION);
    
        if(in_array(strtolower($extension), $denied)){
            echo '{"status":"error"}';
            exit;
        }
    
        if(move_uploaded_file($_FILES['upl']['tmp_name'], 'uploads/'.$_FILES['upl']['name'])){
            echo '{"status":"success"}';
            exit;
        }
    }
    
    echo '{"status":"error"}';
    exit;
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?