基于web的文件管理/目录结构展示(ufinder、elfinder)……的心路历程

本文探讨了如何使用JavaScript插件创建在线文件管理器,包括展示、上传、下载等基本功能。对比了treeview、zTree及elfinder等插件,并解决了中文文件名显示问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

    要在网页做一个类似windows“我的电脑”那种文件夹文件的展示,并且能上传下载删除重命名等功能。

(一)找JS插件,读取文件夹内容,利用插件展示

1.看到几个“推荐n款xxx的好用插件”,看了两个,一个treeview,一个叫ztree。

读取文件内容的php代码是在百度知道看到的,改了一下。

function my_dir($directory)
{
	echo "<ul id='browser' class='filetree'>
			<li><span class=\"folder\">$directory</span>
				<ul>";
	$directory = iconv("utf-8","gb18030" , $directory);
	tree($directory);

	echo '</ul>
		</li>
		</ul>';


}
function tree($directory) 
{ 
	$mydir=dir($directory); 
	while($file=$mydir->read())
	{
		$filename = iconv("gb18030", "utf-8", $file);
		//目录下的文件是文件夹 
		if((is_dir("$directory/$file")) AND ($file!=".") AND ($file!=".."))
		{ 
			echo "<li><span class=\"folder\">$filename</span>
						<ul>"; 
			tree("$directory/$file"); 
			echo '</ul>
				</li>';
		}
		//文件
		elseif (($file!=".") AND ($file!=".."))
		{ 
			echo "<li><span class=\"file\">$filename</span></li>"; 
			/*echo($file);
			echo($filename);*/
		} 
	} 
	$mydir->close(); 
}

效果大概是这样:

215313_UhU0_2421148.png

但是只能展示,功能不足,虽然有几种样式,但不够美观。

2. zTree自带编辑、异步等功能,但是没有后台程序,放弃。

(二)在线文档编辑插件/工具/控件。

悲剧就是从这里开始的。

找了很多,

  1. ajaxexplorer(好像叫这个名字)(后来改名叫pydio)、KODExplorer什么的,都是做好的整个系统样,不是我要找的只是插件,放弃

2.最开始的ufinder,后来兜兜转转找的elfinder,外观都是我需要的,大概是这样:

092224_yxJ8_2421148.png

   这两个基本都差不多,感觉elfinder比ufinder好看一点点,功能多一点,只需要修改语言引入的<script>和lang的值就支持中文(和各种语言)了,当然,代码也更复杂更难理解。

    把特!遇到中文的文件却读不出来。

    后来发现原因是我的文件是在windows系统下,它们的编码都是GBK,而代码的编码都是UTF-8,代码中的json_encode函数也只支持utf8编码。解决思路有两种,一是把所有函数参数接收参数后、返回值之前用iconv进行转码,在函数内部使用代码本身的utf8,将ufinder的init和ls函数(感觉是初始化和显示的函数)改过之后能显示中文文件夹了,想了一下,重命名、删除、新建,函数太多,改起来太累,有没有其他方法。第二种,把代码中的数据GBK编码,以为这样就跟windows统一了。但是失败了,因为json_encode只支持utf8。

于是在网上找到一个能把GBK编码成json的函数:

function ch_json_encode($data) {
   
   function ch_urlencode($data) {
       if (is_array($data) || is_object($data)) {
           foreach ($data as $k => $v) {
               if (is_scalar($v)) {
                   if (is_array($data)) {
                       $data[$k] = urlencode($v);
                   } else if (is_object($data)) {
                       $data->$k = urlencode($v);
                   }
               } else if (is_array($data)) {
                   $data[$k] = ch_urlencode($v); //µÝ¹éµ÷Óøú¯Êý
               } else if (is_object($data)) {
                   $data->$k = ch_urlencode($v);
               }
           }
       }
       return $data;
   }
   
   $ret = ch_urlencode($data);
   $ret = json_encode($ret);
   return urldecode($ret);
}

    再后来,看到哪个网页说json都不支持gbk我就哭了。

    迫不得已,第三种思路,想有没有其他直接支持windows下文件的插件,于是找到了elfinder。后来发现虽然它支持中文,但是windows下的GBK还是读不出文件。不过有一点比ufinder好,ufinder遇到中文文件,整个所在文件夹内所有文件都会显示不出,而elfinder只是单个文件出错。

    目前,准备修改按第一种想法,改……

    所以,有没有人有现成的、或者简单的解决方法啊 TT……


    后续

    由于这个功能是要在linux下使用的,gbk编码的文件无法读取的问题直接就忽略掉了,所以也没找到解决的方法。==

    如果是在linux下使用的话,只需要修改JS的引入就可以支持中文了。再可能就是需要修改一下文件夹的权限;再然后就是对中文文件名的检查。在 http://www.oschina.net/question/921067_83470  中3楼“ywh1981”的方法有效:

    elFinderVolumeDriver.class.php文件中有一句 

            'acceptedName'    => '/^\w[\w\s\.\%\-\(\)\[\]]*$/u',

    这一项是用于检查文件和目录名称的正则的,把它设置为'',对新建或者上传的文件目录名就不检查了。

    这样,就结束了,linux下基本能用了。


转载于:https://my.oschina.net/u/2421148/blog/482526

KODExplorer是款开源的Web在线文件管理、代码编辑器。它提供了类windows经典用户界面,一整套在线文件管理文件预览、编辑、上传下载、在线解压缩、音乐播放功能。让你直接在浏览器端实现web开发、源码文件预览、网站部署的同时拥有与本地操作一样方便、快捷、安全的体验。 完美取代落后的FTP工具:可用于服务器文件管理,支持图片、音乐、视频预览,在线解压缩,文件夹拖拽上传……。 在线编程:支持几乎所有编程语言的在线编辑、代码自动补全(高亮,多光标编辑.堪比本地的sublime) 极佳的操作体验:极其便捷的快捷键支持,让你拥有本地化的体验 中文等多语言支持:中文编码全面兼容,文件编辑自动适配。 超快的速度:全面采用Ajax+Json进行数据通信,毫秒级的响应速度; 全平台兼容性:Win Linux Mac (Apache、Nginx、IIS) 使用场景: 取代古老的FTP,服务端、客户端软件等复杂的安装配置。kod可以一键安装随处使用. 你可以用它来管理你的服务器(备份,在线解压缩,版本发布....) 你可以把他当做管理linux的一个操作系统界面 可以用来作为私有云存储系统,存储你的文件... 当然你也可以用来分享文件 更多场景等你来挖掘!…… 设计理念 传承经典,追求创新,为用户提供方便快捷、安全易用的在线云管理系统。 面向用户 目前KODExplorer系统管理主要定位在个人云主机、中小企业云资源管理、网盘管理、中小型网站管理等。Web开发者&站长(老鸟):在线编辑、压缩备份、部署,经典windows界面操作,上手容易,远离了主机的SSH、ftp复杂枯燥的命令操作。 个人私有云(菜鸟):管理网盘资源,同样经典windows界面操作,可以就地浏览网盘音乐、视屏文件,上传下载快捷方便。 特色 像使用操作系统一样使用体验,右键操作,拖拽,快捷键…… 框中选择,拖拽移动,拖拽上传,在线编辑器,影音播放器,解压缩。全面ajax保证性能和体验! 各个功能直接无缝连接;以对话框形式存在,多任务管理等功能 完备的中文支持,各种情况下乱码解决; 文件管理 文件选择:单选,鼠标框选,shift连选,ctrl随意选择,键盘上下左右、home、end选择。 文件操作:选择文件后,可以进行复制,剪切,删除,属性查看,压缩,重命名,打开预览等操作…… 文件上传:多文件批量上传;html5拖拽上传(拖拽到窗口实现无缝上传) 右键功能:文件右键,文件夹右键,多选后右键操作,桌面右键,树目录右键操作,右键菜单绑定快捷键 (全选——复制——剪切——粘贴——删除——重命名,设置……) 文件浏览:列表模式,图标模式;双击进入子文件夹;地址栏操作;打开文件夹记录逆势操作记录(前进后退) 支持拖拽操作:选中后拖拽,实现剪切到指定文件夹功能 快捷键操作:delete删除,ctrl+A全选,ctrl+C复制,ctrl+X剪切,up/down/left/right/home/end选择文件 在线预览 文件预览:文本文件内容查看编辑保存;html,swf文件预览, 图片预览:自动生成缩略图,图片幻灯片播放; 音频播放:在线播放音乐,视频文件;支持mp3,wma,mid,aac,wav;mp4, 视频播放:在线视频文件播放,支持格式:flv,f4v,3gp 在线编辑 支持60多种代码(数据文件)高亮 支持多标签:同时编辑多份文件,拖动标签可以切换顺序;支持最大化模式 主题切换:选择你喜欢的编程风格 zendcodeing支持,从此爱上在线编程 查找、替换;撤销反撤销,维持历史记录 自动补全[],{},"",';自动换行,自定义字体,代码折叠等诸多实用功能 文件管理器:可以像使用本地我的电脑那样使用它 文件编辑器:支持几乎所有编程语言高亮,支持文档多标签。
KODExplorer是款开源的Web在线文件管理、代码编辑器。它提供了类windows经典用户界面,一整套在线文件管理文件预览、编辑、上传下载、在线解压缩、音乐播放功能。让你直接在浏览器端实现web开发、源码文件预览、网站部署的同时拥有与本地操作一样方便、快捷、安全的体验。 完美取代落后的FTP工具:可用于服务器文件管理,支持图片、音乐、视频预览,在线解压缩,文件夹拖拽上传……。 在线编程:支持几乎所有编程语言的在线编辑、代码自动补全(高亮,多光标编辑.堪比本地的sublime) 极佳的操作体验:极其便捷的快捷键支持,让你拥有本地化的体验 中文等多语言支持:中文编码全面兼容,文件编辑自动适配。 超快的速度:全面采用Ajax+Json进行数据通信,毫秒级的响应速度; 全平台兼容性:Win Linux Mac (Apache、Nginx、IIS) 使用场景: 取代古老的FTP,服务端、客户端软件等复杂的安装配置。kod可以一键安装随处使用. 你可以用它来管理你的服务器(备份,在线解压缩,版本发布....) 你可以把他当做管理linux的一个操作系统界面 可以用来作为私有云存储系统,存储你的文件... 当然你也可以用来分享文件 更多场景等你来挖掘!…… 设计理念 传承经典,追求创新,为用户提供方便快捷、安全易用的在线云管理系统。 面向用户 目前KODExplorer系统管理主要定位在个人云主机、中小企业云资源管理、网盘管理、中小型网站管理等。Web开发者&站长(老鸟):在线编辑、压缩备份、部署,经典windows界面操作,上手容易,远离了主机的SSH、ftp复杂枯燥的命令操作。 个人私有云(菜鸟):管理网盘资源,同样经典windows界面操作,可以就地浏览网盘音乐、视屏文件,上传下载快捷方便。 特色 像使用操作系统一样使用体验,右键操作,拖拽,快捷键…… 框中选择,拖拽移动,拖拽上传,在线编辑器,影音播放器,解压缩。全面ajax保证性能和体验! 各个功能直接无缝连接;以对话框形式存在,多任务管理等功能 完备的中文支持,各种情况下乱码解决; 文件管理 文件选择:单选,鼠标框选,shift连选,ctrl随意选择,键盘上下左右、home、end选择。 文件操作:选择文件后,可以进行复制,剪切,删除,属性查看,压缩,重命名,打开预览等操作…… 文件上传:多文件批量上传;html5拖拽上传(拖拽到窗口实现无缝上传) 右键功能:文件右键,文件夹右键,多选后右键操作,桌面右键,树目录右键操作,右键菜单绑定快捷键 (全选——复制——剪切——粘贴——删除——重命名,设置……) 文件浏览:列表模式,图标模式;双击进入子文件夹;地址栏操作;打开文件夹记录逆势操作记录(前进后退) 支持拖拽操作:选中后拖拽,实现剪切到指定文件夹功能 快捷键操作:delete删除,ctrl+A全选,ctrl+C复制,ctrl+X剪切,up/down/left/right/home/end选择文件 在线预览 文件预览:文本文件内容查看编辑保存;html,swf文件预览, 图片预览:自动生成缩略图,图片幻灯片播放; 音频播放:在线播放音乐,视频文件;支持mp3,wma,mid,aac,wav;mp4, 视频播放:在线视频文件播放,支持格式:flv,f4v,3gp 在线编辑 支持60多种代码(数据文件)高亮 支持多标签:同时编辑多份文件,拖动标签可以切换顺序;支持最大化模式 主题切换:选择你喜欢的编程风格 zendcodeing支持,从此爱上在线编程 查找、替换;撤销反撤销,维持历史记录 自动补全[],{},"",';自动换行,自定义字体,代码折叠等诸多实用功能 文件管理器:可以像使用本地我的电脑那样使用它 文件编辑器:支持几乎所有编程语言高亮,支持文档多标签。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值