【问题标题】:PHP OOP handle errors notification for UIPHP OOP 处理 UI 的错误通知
【发布时间】:2015-05-19 10:04:41
【问题描述】:

我正在寻找为用户显示错误的最佳方式,我正在使用 Class File() 和配置文件页面。 Class File() 将处理以下内容: - 检查文件扩展名 - 检查文件是否已经存在 - 分解并创建链接文件 && 插入到数据库的链接 - 上传文件到项目文件夹内的文件夹目录

代码除了显示错误外都正常工作,例如扩展错误会显示最后一个错误,而不是停止执行并显示扩展错误。

另外,如果该文件已经存在于数据库 && 文件夹目录中,php 函数 move_uploaded_file 将显示并错误“警告:无法打开流:权限被拒绝”

感谢您的帮助

    class File {

    private $file = array();
    private $file_up = '';
    private $pdo = '';
    private $error = '';
    private $regex_file = '/^[a-z0-9][a-z0-9]{4,20}.jpg|.jpeg|.png|.gif|.txt|.doc|.docx|.pdf|.xlsx|.xlm|.xls|.pub|.one|.pptx$i/';

    /**
     * [__construct connection ]
     * @param [int] $id [Unique user_id retrieved from database (from include/header.inc)]
     * Construct database connection using PDO
     * 
     */
    public function __construct($id)
    {
        $this->pdo = new PDO('mysql:host='.DB_HOST.';dbname='.DB_NAME, DB_USER, DB_PASS, array(PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION));
        $sql = 'SELECT `file_name`, `file_extention` FROM `users`'
                 .'JOIN `file`'
                 .'ON users.`user_id` = file.`user_id`'
                 .'WHERE users.`user_id` = :id';
        $stmt = $this->pdo->prepare($sql);
        $stmt->execute(array(':id' => $id));
        while($row = $stmt->fetch(PDO::FETCH_ASSOC)) {
            $this->file[] = $row['file_name'] . '.' . $row['file_extention'];
        }
    }

    /**
     * [displayFile extention]
     * @return [link] [description]
     */
    public function displayFile() 
    {
        $output = '';
        $link = $this->file;
        foreach($link as $row) {
            $output .= '<table class="table table-bordered table-hover"';
            $output .= '<thead><tr>';
            $output .= '<th><a href="../file_user/'.$row.'><i class="fa fa-folder"></i>&nbsp&nbsp'.$row.'</a><br /></th>';
            $output .= '</tr></thead>';
            $output .= '</table>';
        }
        return $output;
    }

    public function checkFile($file)
    {
        $this->file_up = strip_tags($file);
        if(!preg_match($this->regex_file, $this->file_up)){
                $this->error = '<b style="color:red">Extention ou nom de fichier incorrect</b>';
        }
        foreach($this->file as $row){
            if($this->file_up == $row){
                $this->error = '<b style="color:red">Fichier ou nom du fichier deja existant</b>';
            }
        }
        if($this->error){
            return $this->error;
        }else{
            $this->file_up = explode(".", $this->file_up);// array
            return $this->file_up;
        }       
    }

    public function getError()
    {
        if($this->error !== ''){
            return $this->error;
        }
    }

    public function uploadFile($array, $id)
    {   
        if(is_array($array)){
            array_push($array, $id);
            $sql = 'INSERT INTO `file`(`file_name`, `file_extention`, `user_id`) VALUES (?, ?, ?)';
            $con = $this->pdo->prepare($sql);
            $con->execute($array);
        }else{
            $this->error = '<b style="color:red">Fichier ne peut etre telecharger</b>';
        }
    }

    public function mvFile($size, $name, $tmp_name)
    {
        $to = 'file_user/';
        if($size <= 2000000){
            move_uploaded_file($tmp_name, $to.$name);
            $this->error = '<b style="color:green">Fichier téléchargé avec succes</b>';
        }else{
            $this->error = '<b style="color:red">Un probleme est survenue veuillez recommencer</b>';
        }
    }
}

和 testing.php 来测试它:

require_once 'class/file.inc';
$error = '';
$id = 2;
$file = new File($id);

 $name = $_FILES['file']['name'];
 $size = $_FILES['file']['size'];
 $type = $_FILES['file']['type'];
 $tmp_name = $_FILES['file']['tmp_name'];



if(isset($_FILES['file'])){
        $file_up = $_FILES['file']['name'];
        $file_up = $file->checkFile($file_up);
        $file->uploadFile($file_up, $id);
        //$file->mvFile($size, $name, $_FILES['file']['tmp_name']);
    if($file->getError()){
        $error = $file->getError();
    }

} // end isset

if($error){
    echo $error;
}

【问题讨论】:

    标签: php oop error-handling


    【解决方案1】:

    两个独立的问题:

    1. 如果您在 checkFile() 方法中检测到任何错误,并且只想获取第一个错误(在我看来这很奇怪;您可以将错误收集到一个数组中),您应该直接返回该错误,而不是继续该方法的其余部分。此外,我会考虑协调返回值。您的方法应该返回错误还是文件名?现在还不是很干净。

    2. 您关于 move_uploaded_file() 的问题似乎与权限相关。检查您的源(tmp 上传)目录和目标以获取 r/w 权限。

    【讨论】:

    • 1.是的,我的 Class File() 可能比这更好的编码,欢迎所有建议。对于错误,我希望代码在检测到错误后立即停止执行并返回它&&如果没有错误返回文件名。 2.好吧,如果权限问题,如果这个文件不存在,为什么我仍然可以上传文件?
    • 对于 1.,只返回错误。这是非常基本的。对于 2.,您正在移动文件,这意味着复制和删除。也许您无法删除 tmp 上传的文件。为了解决这个问题,您可以使用 copy() 代替,然后使用 tmp 上传文件的 unlink()。
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2019-03-30
    • 2015-06-15
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多