前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >关于UEditor远程图片上传失败的解决办法

关于UEditor远程图片上传失败的解决办法

作者头像
胡尐睿丶
发布2022-03-23 17:21:43
8620
发布2022-03-23 17:21:43
举报
文章被收录于专栏:代码小睿

  因为单纯喜欢 UEditor 的界面,于是把项目中原先的编辑器进行的替换,但在后续操作中发现一些问题,就是远程图片上传。

  远程图片上传是个很有意思的东西,比如你从别的网站复制一段文件,如果文字中带有图片,编辑器会自动将图片提取出来,进行上传,从而不用担心远程图片失效后,自己本地也无法浏览。

  通过检查,发现远程图片上传的操作页面是:getRemoteImage.php 。打开后我们先配置 savePath ,因为不同用户使用,需要存放到不同的目录,以免混乱,也方便管理

  修改后代码:

代码语言:javascript
复制
    //远程抓取图片配置
	if(isset($_SESSION['admin'])){
		$myPath = 'http://www.cnblogs.com/../dofiles/ueditorUpload/admin/'.$_SESSION['admin']['id'].'/';
	}else if(isset($_SESSION['user'])){
		$myPath = 'http://www.cnblogs.com/../dofiles/ueditorUpload/user/'.$_SESSION['user']['id'].'/';
	}else{
		$myPath = 'http://www.cnblogs.com/../dofiles/ueditorUpload/unkonw/';
	}
    $config = array(
        "savePath" => $myPath ,            //保存路径
        "allowFiles" => array( ".gif" , ".png" , ".jpg" , ".jpeg" , ".bmp" ) , //文件允许格式
        "maxSize" => 3000                    //文件大小限制,单位KB
    );

  然后问题就来了,UEditor 里,文件、图片上传都是通过 Uploader.class.php 这个php类操作的,但远程图片上传则不是。

  我在85行发现,创建路径的时候,单纯的使用了mkdir进行来创建,因为mkdir不能创建带有层级的路径,所以导致在路径如果不存在的情况下,复制远程图片上传失败。

  知道问题处理起来就容易了,我先写一个循环创建文件目录的函数(因为之前写过,这里就直接拿来用了):

代码语言:javascript
复制
    //连续创建带层级的文件夹
    function recursive_mkdir($folder){
        $folder = preg_split( "/[\\\\\/]/" , $folder );
        $mkfolder = '';
        for($i=0; isset($folder[$i]); $i++){
            if(!strlen(trim($folder[$i]))){
                continue;
            }
            $mkfolder .= $folder[$i];
            if(!is_dir($mkfolder)){
                mkdir("$mkfolder",0777);
            }
            $mkfolder .= DIRECTORY_SEPARATOR;
        }
    }

  然后修改85行:

代码语言:javascript
复制
    //创建保存位置
    $savePath = $config[ 'savePath' ];
    if ( !file_exists( $savePath ) ) {
        recursive_mkdir($savePath);
        //mkdir( "$savePath" , 0777 );
    }

  这样一来,就没有问题了。

  这问题也已经提交给百度官方,希望修正。

  测试UEditor版本为1.2.3.0,如果之前版本也有相关问题,按照修改思路去修改应该也可以解决。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2012-08-29 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档