更新或删除记录时如何从数据库和文件夹位置永久删除图像

时间:2015-04-07 08:35:37

标签: php yii

我遇到了问题。我的记录有一个图像选项,但是当我更新记录或删除记录时,它只影响数据库表,图像文件仍然位于文件夹位置。我已经阅读了关于php的unlink功能,但我不知道如何在我的情况下使用它。 这是我的代码http://pastebin.com/KQZyAuA0,用于更新和删除操作,如果有人知道答案,那么请与我分享。

1 个答案:

答案 0 :(得分:2)

您可以将$ model-> save()的代码更改为此,因此在重定向之前,请检查目录中是否存在旧图像,将其删除。

        $oldThumb = Yii::getPathOfAlias('media') . '/album/optimized/' . $model_old_data->photo;
        $oldOptimized = Yii::getPathOfAlias('media') . '/album/optimized/' . $model_old_data->photo;

        if ($model->save()) {
            if (file_exists($oldThumb)) {
                unlink($oldThumb);
            }
            if (file_exists($oldOptimized)) {
                unlink($oldOptimized);
            }
            $this->redirect(array('view', 'id' => $model->id));
        }

必须将动作删除更改为

    public function actionDelete($id)
    {
        if (Yii::app()->request->isPostRequest) {
// we only allow deletion via POST request
            $model_old_data = $this->loadModel($id);
            $oldThumb = Yii::getPathOfAlias('media') . '/album/optimized/' . $model_old_data->photo;
            $oldOptimized = Yii::getPathOfAlias('media') . '/album/optimized/' . $model_old_data->photo;

            $model = $this->loadModel($id);
            if ($model->delete()) {
                if (file_exists($oldThumb)) {
                    unlink($oldThumb);
                }
                if (file_exists($oldOptimized)) {
                    unlink($oldOptimized);
                }
            }

// if AJAX request (triggered by deletion via admin grid view), we should not redirect the browser
            if (!isset($_GET['ajax'])) {
                $this->redirect(isset($_POST['returnUrl']) ? $_POST['returnUrl'] : array('admin'));
            }
        } else {
            throw new CHttpException(400, 'Invalid request. Please do not repeat this request again.');
        }
    }