云盘开发利器elfinder

elFinder 是一个基于 Web 的文件管理器,灵感来自 Mac OS X 的 Finder 程序。

image
image

elFinder 的安装方法很简单,按照以下几个步骤即可:

1. 引入 jQuery 和 jQuery UI 包

<script src="js/jquery.js" type="text/javascript" charset="utf-8"></script>  
<script src="js/jquery-ui-1.7.2.custom.min.js" type="text/javascript" charset="utf-8"></script>  
<link rel="stylesheet" href="js/ui-themes/base/ui.all.css" type="text/css" media="screen" charset="utf-8"> 

2. 引入 elFinder 包

<script src="js/elfinder.min.js" type="text/javascript" charset="utf-8"></script> 
<link rel="stylesheet" href="css/elfinder.css" type="text/css" media="screen" charset="utf-8">  

3. 引入本地化包

<script src="js/i18n/elfinder.ru.js" type="text/javascript" charset="utf-8"></script>  

4. 初始化服务器端的连接器

<script type="text/javascript" charset="utf-8">  
   $().ready({  
     $('#my-div').elfinder({  
       url : 'connectors/php/connector.php',  
       lang : 'ru'  
     })  
   })  
</script>  

从这段代码可以看出,elfinder主要提供的是一个基于jquery的管理前端,当用户执行“浏览目录”“查看文件”“删除文件”等操作的时候,实际上,前端js会链接到后端的对应操作模块(类似于connector.php?command=dir)。

目前已经有一些较成熟的elfinder后端,包括PHP、Java、.NET等不同版本的。这里介绍一款基于Java-Servlet的后端:elfinder-2.x-servlet,该项目完全开源,地址:https://github.com/bluejoe2008/elfinder-2.x-servlet

elfinder-2.x-servlet支持如下操作:

  • DIM
  • DUPLICATE
  • FILE
  • GET
  • LS
  • MKDIR
  • MKFILE
  • OPEN
  • PARENT
  • PASTE
  • PUT
  • RENAME
  • RM
  • SEARCH
  • SIZE
  • TMB
  • TREE
  • UPLOAD

elfinder-2.x-servlet基于spring框架开发,因此也很容易与java web系统相集成。

<servlet>  
    <servlet-name>elfinder</servlet-name>  
    <servlet-class>org.springframework.web.servlet.DispatcherServlet  
    </servlet-class>  
</servlet>  
  
<servlet-mapping>  
    <servlet-name>elfinder</servlet-name>  
    <url-pattern>/elfinder-servlet/*</url-pattern>  
</servlet-mapping>  

对应的spring配置文件:

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:p="http://www.springframework.org/schema/p"
    xmlns:context="http://www.springframework.org/schema/context"
    xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd   
       http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-3.0.xsd   
       http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.0.xsd   
       http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.0.xsd">

    <context:annotation-config />
    <context:component-scan base-package="cn.bluejoe.elfinder.controller" />

    <bean
        class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter" />

    <!-- find appropriate command executor for given command -->
    <bean id="commandExecutorFactory"
        class="cn.bluejoe.elfinder.controller.executor.DefaultCommandExecutorFactory">
        <property name="classNamePattern"
            value="cn.bluejoe.elfinder.controller.executors.%sCommandExecutor" />
        <property name="fallbackCommand">
            <bean
                class="cn.bluejoe.elfinder.controller.executors.MissingCommandExecutor" />
        </property>
        <property name="map">
            <map>
                <!--
                <entry key="tree">
                    <bean class="cn.bluejoe.elfinder.controller.executors.TreeCommandExecutor" />
                </entry>
                -->
            </map>
        </property>
    </bean>

    <!-- FsService is often retrieved from HttpRequest -->
    <!-- while a static FsService is defined here -->
    <bean id="fsServiceFactory" class="cn.bluejoe.elfinder.impl.StaticFsServiceFactory">
        <property name="fsService">
            <bean class="cn.bluejoe.elfinder.impl.DefaultFsService">
                <property name="serviceConfig">
                    <bean class="cn.bluejoe.elfinder.impl.DefaultFsServiceConfig">
                        <property name="tmbWidth" value="80" />
                    </bean>
                </property>
                <property name="volumeMap">
                    <!-- two volumes are mounted here -->
                    <map>
                        <entry key="A">
                            <bean class="cn.bluejoe.elfinder.localfs.LocalFsVolume">
                                <property name="name" value="MyFiles" />
                                <property name="rootDir" value="/tmp/a" />
                            </bean>
                        </entry>
                        <entry key="B">
                            <bean class="cn.bluejoe.elfinder.localfs.LocalFsVolume">
                                <property name="name" value="Shared" />
                                <property name="rootDir" value="/tmp/b" />
                            </bean>
                        </entry>
                    </map>
                </property>
                <!--
                <property name="volumes">
                    <list>
                        <bean class="cn.bluejoe.elfinder.localfs.LocalFsVolume"> 
                            <property name="name" value="MyFiles" />
                            <property name="rootDir" value="/tmp/a" />
                        </bean>
                        <bean class="cn.bluejoe.elfinder.localfs.LocalFsVolume">
                            <property name="name" value="Shared" />
                            <property name="rootDir" value="/tmp/b" /> 
                        </bean>
                    </list>
                </property>
                -->
                <property name="securityChecker">
                    <bean class="cn.bluejoe.elfinder.impl.FsSecurityCheckerChain">
                        <property name="filterMappings">
                            <list>
                                <bean class="cn.bluejoe.elfinder.impl.FsSecurityCheckFilterMapping">
                                    <property name="pattern" value="A_.*" />
                                    <property name="checker">
                                        <bean class="cn.bluejoe.elfinder.impl.FsSecurityCheckForAll">
                                            <property name="readable" value="true" />
                                            <property name="writable" value="true" />
                                        </bean>
                                    </property>
                                </bean>
                                <bean class="cn.bluejoe.elfinder.impl.FsSecurityCheckFilterMapping">
                                    <property name="pattern" value="B_.*" />
                                    <property name="checker">
                                        <bean class="cn.bluejoe.elfinder.impl.FsSecurityCheckForAll">
                                            <property name="readable" value="true" />
                                            <property name="writable" value="false" />
                                        </bean>
                                    </property>
                                </bean>
                            </list>
                        </property>
                    </bean>
                </property>
            </bean>
        </property>
    </bean>
</beans>

这里面展示了一个包含了2个卷的文件目录结构,分别映射到/tmp/a和/tmp/b目录下。

但一般云盘系统可能不会严格对应于某个静态的目录,甚至会根据用户的账号来动态构造目录结构。

elfinder-2.x-servlet充分考虑到了这一点,提供了FsServiceFactory接口,用以实现这种动态的需求:

public class MyServiceFactory implements FsServiceFactory  
{  
    FsService getFileService(HttpServletRequest request, ServletContext servletContext)  
    {  
        //获取到用户名  
        String username = request.getUserPrincipal().getName();  
        //读取文件资源表  
        //构造FsVolume及子目录。。。  
          
    }  
}  

更多帮助信息参见https://github.com/bluejoe2008/elfinder-2.x-servlet

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,732评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,496评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,264评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,807评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,806评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,675评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,029评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,683评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 41,704评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,666评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,773评论 1 332
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,413评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,016评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,978评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,204评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,083评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,503评论 2 343

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,596评论 18 139
  • Spring Boot 参考指南 介绍 转载自:https://www.gitbook.com/book/qbgb...
    毛宇鹏阅读 46,733评论 6 342
  • 我的好朋友叫小凯凯,他和我是邻居,我们住的很近。他和我都是属小兔子的,但是他的个子比我高很多。不过他还叫我...
    张余蔚阅读 393评论 0 0
  • 最近创投圈,讨论最多的就是消费升级,投资人,创业者,大v,媒体们都在呼吁,这一波浪潮是消费升级的浪潮,有2亿中产阶...
    洞天水月阅读 155评论 0 0
  • 已经是凌晨2点多,晚上家里来了客人,被迫把我书房沙发的位置让给客人睡,给客人泡了一杯茶,便放下手头的事,拿着笔记本...
    Dotartisan阅读 283评论 0 0