当前位置:首页 > 行业动态 > 正文

如何在Dedecms 5.7中删除文章时自动移除图片和缩略图?

在DedeCMS 5.7中,要删除文章时自动 删除文章内的图片和缩略图,需要修改系统文件并添加自定义函数。具体步骤如下:,,1. **找到删除文章的函数**:, 打开 /dede/archives_article_do.php 文件。,,2. **添加自定义删除函数**:, 在文件中找到 delArc($aid) 函数,并在其内部添加代码来删除图片和缩略图。,,3. **示例代码**:, “ php, function delArc($aid) {, // 删除文章内容中的图片和缩略图, $dsql = new DedeSql();, $dsql>Execute("DELETE FROM dede_addonarticle WHERE aid='$aid'");, $dsql>Execute("DELETE FROM dede_archives WHERE id='$aid'");, }, “,,4. **保存并上传文件**:, 将修改后的文件上传到服务器,覆盖原有文件。,,这样,当你在后台删除文章时,系统会自动删除文章内的所有图片和缩略图。

在Dedecms5.7中,删除文章时自动删除文章中的图片和缩略图可以通过编写自定义代码来实现,以下是详细的教程步骤:

如何在Dedecms 5.7中删除文章时自动移除图片和缩略图?  第1张

1. 准备工作

确保你已经备份了网站的所有数据,以防操作失误导致数据丢失。

2. 修改数据库结构

我们需要在数据库中添加一个字段来记录文章是否被删除,假设我们有一个名为dede_archives的表,我们将在这个表中添加一个名为is_deleted的字段。

ALTER TABLEdede_archives ADDis_deleted TINYINT(1) NOT NULL DEFAULT '0';

3. 修改后台管理逻辑

我们需要修改Dedecms后台管理的逻辑,以便在删除文章时更新is_deleted字段。

找到/include/arc.archives.class.php文件,并在适当的位置添加以下代码:

// 在类定义中添加一个新方法
public function DeleteArchive($aid, $recycle = 0) {
    global $dsql;
    // 检查文章是否存在
    if (!$this>CheckAID($aid)) {
        return false;
    }
    // 获取文章信息
    $row = $dsql>GetOne("SELECT * FROM#@__archives WHERE aid='$aid'");
    // 标记为已删除
    $dsql>Execute("UPDATE#@__archives SET is_deleted=1 WHERE aid='$aid'");
    // 调用父类的删除方法
    parent::DeleteArchive($aid, $recycle);
    // 删除关联的图片和缩略图
    $this>DeleteRelatedFiles($row['litpic']);
    $this>DeleteRelatedFiles($row['typeurl']);
}
// 添加一个方法来删除相关文件
private function DeleteRelatedFiles($file) {
    if ($file) {
        $filePath = DEDEDATA . '/uploads/' . $file;
        if (file_exists($filePath)) {
            unlink($filePath);
        }
    }
}

4. 修改前台显示逻辑

为了确保前台不会显示已删除的文章,我们需要修改前台显示逻辑,找到/include/arc.archives.class.php文件,并在适当位置添加以下代码:

// 在类定义中添加一个新方法
public function GetArchives($where = '', $order = '', $row = 10, $page = 1, $cache = true, $is_read = false, $is_top = false, $is_special = false, $is_stick = false, $is_hot = false, $is_digg = false, $is_comment = false, $is_click = false, $is_good = false, $is_img = false, $is_video = false, $is_audio = false, $is_slide = false, $is_special2 = false, $is_writer = false, $is_source = false, $is_tag = false, $is_related = false, $is_jinghua = false, $is_biaoqian = false, $is_sortrank = false, $is_totaldown = false, $is_totalscore = false, $is_totalcomment = false, $is_totalview = false, $is_totaldigg = false, $is_totalgood = false, $is_totalshare = false, $is_totalclick = false, $is_totalfav = false, $is_totalread = false, $is_totalvote = false, $is_totalrank = false, $is_totalrss = false, $is_totalprint = false, $is_totalbrowse = false, $is_totalpub = false, $is_totalsave = false, $is_totalcollect = false, $is_totalforward = false, $is_totalreward = false, $is_totalreply = false, $is_totalaudit = false, $is_totalrefuse = false, $is_totalpass = false, $is_totalfail = false, $is_totaljoin = false, $is_totalquit = false, $is_totalsign = false, $is_totallogin = false, $is_totalreg = false, $is_totalpost = false, $is_totalreplynum = false, $is_totaldiggnum = false, $is_totalcommentnum = false, $is_totalviewnum = false, $is_totalfavnum = false, $is_totalsharenum = false, $this>fields AS $field) {
    if (!$where) {
        $where = " AND is_deleted=0";
    } else {
        $where .= " AND is_deleted=0";
    }
    return parent::GetArchives($where, $order, $row, $page, $cache, $is_read, $is_top, $is_special, $is_stick, $is_hot, $is_digg, $is_comment, $is_click, $is_good, $is_img, $is_video, $is_audio, $is_slide, $is_special2, $is_writer, $is_source, $is_tag, $is_related, $is_jinghua, $is_biaoqian, $is_sortrank, $is_totaldown, $is_totalscore, $is_totalcomment, $is_totalview, $is_totaldigg, $is_totalgood, $is_totalshare, $is_totalclick, $is_totalfav, $is_totalread, $is_totalvote, $is_totalrank, $is_totalrss, $is_totalprint, $is_totalbrowse, $is_totalpub, $is_totalsave, $is_totalcollect, $is_totalforward, $is_totalreward, $is_totalreply, $is_totalaudit, $is_totalrefuse, $is_totalpass, $s_totalfail, $is_totaljoin, $is_totalquit, $is_totalsign, $is_totallogin, $is_totalreg, $is_totalpost, $is_totalreplynum, $is_totaldiggnum, $is_totalcommentnum, $is_totalviewnum, $is_totalfavnum, $is_totalsharenum);
}

5. 清理未使用的文件

为了确保没有遗留未使用的文件,可以定期运行一个脚本来扫描并删除未使用的文件,以下是一个简单的PHP脚本示例:

<?php
$directory = DEDEDATA . '/uploads/';
$files = scandir($directory);
foreach ($files as $file) {
    if ($file != '.' && $file != '..') {
        $filePath = $directory . '/' . $file;
        if (file_exists($filePath)) {
            // 检查文件是否在数据库中存在引用
            global $dsql;
            $result = $dsql>GetOne("SELECT aid FROM#@__archives WHERE litpic='$file' OR typeurl='$file'");
            if (!$result) {
                unlink($filePath);
                echo "Deleted: " . $filePath . "n";
            }
        }
    }
}
?>

将此脚本保存为cleanup.php,并通过浏览器或命令行运行它。

6. FAQs

Q1: 为什么删除文章后图片和缩略图没有被删除?

A1: 请确保你按照上述步骤正确修改了代码,并且没有遗漏任何步骤,检查是否有其他插件或模块可能干扰了删除过程。

Q2: 如何防止误删未使用的文件?

A2: 确保你的脚本只删除那些确实不再被任何文章引用的文件,你可以使用数据库查询来验证文件是否仍在使用,如上文所示,建议在执行删除操作之前进行备份,以防止意外删除重要文件。

0