当前位置:首页 > 网站管理 > 正文内容

UEditor 添加在线管理图片删除功能

wzccxx5年前 (2021-06-05)网站管理6

第一,需要添加一个 php 文件来实现删除功能,文件添加到: ueditor\php\action_delete.php 代码内容:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
<?php
  
/*---------------------------
 * wang
 *zhibeiwang.blog.51cto.com
 * 2017-08-10
 * action_delete.php
 * 删除 Ueditor 目录下的文件
 *---------------------------*/
  
try {
    //获取路径
    $path $_POST['path'];
    $path str_replace('../'''$path);
    $path str_replace('/''\\'$path);
     
    //安全判断(只允许删除 ueditor 目录下的文件)
    if(stripos($path'\\ueditor\\') !== 0)
    {
        return '非法删除';
    }
     
    //获取完整路径
    $path $_SERVER['DOCUMENT_ROOT'].$path;
    if(file_exists($path)) {
        //删除文件
        unlink($path);
        return 'ok';
    else {
        return '删除失败,未找到'.$path;
    }
catch (Exception $e) {
    return '删除异常:'.$e->getMessage();
}

第二,需要在 ueditor\php\controller.php 文件的 switch 中添加命令 deleteimage 的处理:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
....
  
switch ($action) {
  
    ....
    
    /* 删除图片命令处理 */
    case 'deleteimage':
         $result include('action_delete.php');
         break;
     
    /* 在 default 之前添加 */
    default:
        $result = json_encode(array(
            'state'=> '请求地址出错'
        ));
        break;
  
}
  
....

第三,在图片上添加删除按钮,需要修改 Js 文件:ueditor\dialogs\image\image.js

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
....
  
/* 在这两句之后添加 */
item.appendChild(img);
item.appendChild(icon);
  
/* 添加删除功能 */
item.appendChild($("<span class='delbtn' url='" + list[i].url + "'></span>").click(function() {
    var del = $(this);
    try{
        window.event.cancelBubble = true; //停止冒泡
        window.event.returnValue = false; //阻止事件的默认行为
        window.event.preventDefault();    //取消事件的默认行为  
        window.event.stopPropagation();   //阻止事件的传播
    } finally {
        if(!confirm("确定要删除吗?")) return;
        $.post(editor.getOpt("serverUrl") + "?action=deleteimage", { "path": del.attr("url") }, function(result) {
            if (result == "ok") del.parent().remove();
            else alert(result);
        });
    }
})[0]);
  
/* 在这一句之前添加 */
this.list.insertBefore(item, this.clearFloat);
  
....

第四,为删除按钮添加一个样式,修改文件:ueditor\dialogs\image\image.css 在最底部添加如下代码:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
/* 在线管理删除按钮样式 */
#online li .delbtn {      
    position: absolute;
    top: 0;
    right: 0;
    border: 0;   
    z-index: 3;
    color: #ffffff;
    display: inline;
    font-size: 12px;
    line-height: 10.5px;
    padding:3px 5px;
    text-align: center;
    background-color: #d9534f;
}


扫描二维码推送至手机访问。

版权声明:本文由泰山森林发布,如需转载请注明出处。

本文链接:https://wzc.tzts.ltd/post/64.html

分享给朋友:

相关文章

根据IP跳转的JS代码

<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /><script src="http...

dede织梦系统升级后,dedecms pagelist 去掉li

首先说文章列表页:对应的类文件是:查找/include/arc.listview.class.php按Ctrl+H键,查找全部替换为空格全部替换为空格全部替换为空格保存,覆盖原文件即可.列表页pagelist 去掉li 对应的类文件是:/i...

真正有效的 dede5.7 按权重排序 解决方法

{dede:arclist titlelen='38' flag='h' noflag='a' isweight='y' orderby='weig...

dede织梦后台系统设置在PHP5.4,5.6环境中不能保存中文参数的解决方法

在没用PHP5.4的环境做Dede后台的时候,织梦58一直没有遇到这个问题,昨天上传一个新的模版到空间去测试发现后台的系统基本参数设置中所有的中文内容都无法保存,关于这个问题,其实以前也听说过,知识一直没有遇到,这是因为网站编码的问题,UT...

Zblog搬家移动网站空间怎么导出导入myqsl数据

Zblog搬家移动网站空间怎么导出导入myqsl数据

在Zblog站点开始运作后,有时我们因为某些原因,比如空间速度慢,比如空间要到期,比如空间不够用等,可能会对网站空间进行搬家的操作,而在移动网站空间过程,最重要的莫过于数据的转移了,那么Zblog搬家移动网站空间怎么导出原来的数据,又如何导...

dede织梦自适应模板首页或者列表图片错位变形解决办法,自定义缩略图尺寸

这篇文章主要为大家详细介绍了织梦自适应模板首页或者列表图片错位变形或者失真解决办法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,有需要的朋友可以收藏方便以后借鉴。     在给用户制作织梦自适应模板的时候...

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。