elfinder-servlet-2

Java backend for "elFinder".

Лицензия

Лицензия

Группа

Группа

org.grapheco
Идентификатор

Идентификатор

elfinder-servlet-2
Последняя версия

Последняя версия

1.4
Дата

Дата

Тип

Тип

war
Описание

Описание

elfinder-servlet-2
Java backend for "elFinder".
Ссылка на сайт

Ссылка на сайт

https://github.com/bluejoe2008/elfinder-2.x-servlet
Система контроля версий

Система контроля версий

https://github.com/bluejoe2008/elfinder-2.x-servlet.git

Скачать elfinder-servlet-2

Как подключить последнюю версию

<!-- https://jarcasting.com/artifacts/org.grapheco/elfinder-servlet-2/ -->
<dependency>
    <groupId>org.grapheco</groupId>
    <artifactId>elfinder-servlet-2</artifactId>
    <version>1.4</version>
    <type>war</type>
</dependency>
// https://jarcasting.com/artifacts/org.grapheco/elfinder-servlet-2/
implementation 'org.grapheco:elfinder-servlet-2:1.4'
// https://jarcasting.com/artifacts/org.grapheco/elfinder-servlet-2/
implementation ("org.grapheco:elfinder-servlet-2:1.4")
'org.grapheco:elfinder-servlet-2:war:1.4'
<dependency org="org.grapheco" name="elfinder-servlet-2" rev="1.4">
  <artifact name="elfinder-servlet-2" type="war" />
</dependency>
@Grapes(
@Grab(group='org.grapheco', module='elfinder-servlet-2', version='1.4')
)
libraryDependencies += "org.grapheco" % "elfinder-servlet-2" % "1.4"
[org.grapheco/elfinder-servlet-2 "1.4"]

Зависимости

compile (13)

Идентификатор библиотеки Тип Версия
commons-codec : commons-codec jar 1.9
commons-io : commons-io jar 2.4
commons-fileupload : commons-fileupload jar 1.3.1
org.apache.commons : commons-lang3 jar 3.3.2
org.springframework : spring-webmvc jar 3.2.3.RELEASE
org.json : json jar 20090211
com.mortennobel : java-image-scaling jar 0.8.6
javax.mail : mail jar 1.4.5
log4j : log4j jar 1.2.17
org.webjars.bower : elfinder jar 2.1.11
org.webjars : jquery jar 1.12.4
org.webjars : jquery-ui jar 1.11.4
org.webjars : jquery-ui-themes jar 1.11.4

provided (1)

Идентификатор библиотеки Тип Версия
javax.servlet : javax.servlet-api jar 3.0.1

Модули Проекта

Данный проект не имеет модулей.

what's elfinder-2.x-servlet

GitHub issues GitHub forks GitHub stars GitHub license

elfinder-2.x-servlet implements a java servlet for elfinder-2.x connector

elfinder is an Open-source file manager for web, written in JavaScript using jQuery and jQuery UI. see also http://elfinder.org

for elfinder-1.2 users, please go to https://github.com/Studio-42/elfinder-servlet.

importing elfinder-2.x-servlet

this project is released as an artifact on the central repostory

use

<dependency>
    <groupId>org.grapheco</groupId>
    <artifactId>elfinder-servlet-2</artifactId>
    <version>1.4</version>
    <classifier>classes</classifier>
</dependency>

to add dependency in your pom.xml

building elfinder-2.x-servlet

the source files includes:

  • src/main/webapp : a normal j2ee application includes elfinder, WEB-INF...
  • src/main/java: source codes for elfinder-servlet
  • src/main/resources: source codes for elfinder-servlet

To build this project with maven run:

mvn install

to run this project within a jetty container use:

mvn jetty:run

using elfinder-2.x-servlet in your web apps

just use following codes to tell elfinder to connect with server-side servlet:

	<script type="text/javascript" charset="utf-8">
		$(document).ready(function() {
			$('#elfinder').elfinder({
				url : 'elfinder-servlet/connector',
			});
		});
	</script>

in your web.xml, following codes should be added to enable the servlet:

<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>

yes! elfinder-2.x-servlet is developed upon SpringFramework (http://springframework.org)

an example elfinder-servlet.xml configuration is shown below:

<!-- find appropriate  command executor for given command-->
<bean id="commandExecutorFactory"
	class="org.grapheco.elfinder.controller.executor.DefaultCommandExecutorFactory">
	<property name="classNamePattern"
		value="org.grapheco.elfinder.controller.executors.%sCommandExecutor" />
	<property name="map">
		<map>
		<!-- 
			<entry key="tree">
				<bean class="org.grapheco.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="org.grapheco.elfinder.impl.StaticFsServiceFactory">
	<property name="fsService">
		<bean class="org.grapheco.elfinder.impl.DefaultFsService">
			<property name="serviceConfig">
				<bean class="org.grapheco.elfinder.impl.DefaultFsServiceConfig">
					<property name="tmbWidth" value="80" />
				</bean>
			</property>
			<property name="volumeMap">
				<!-- two volumes are mounted here -->
				<map>
					<entry key="A">
						<bean class="org.grapheco.elfinder.localfs.LocalFsVolume">
							<property name="name" value="MyFiles" />
							<property name="rootDir" value="/tmp/a" />
						</bean>
					</entry>
					<entry key="B">
						<bean class="org.grapheco.elfinder.localfs.LocalFsVolume">
							<property name="name" value="Shared" />
							<property name="rootDir" value="/tmp/b" />
						</bean>
					</entry>
				</map>
			</property>
			<property name="securityChecker">
				<bean class="org.grapheco.elfinder.impl.FsSecurityCheckerChain">
					<property name="filterMappings">
						<list>
							<bean class="org.grapheco.elfinder.impl.FsSecurityCheckFilterMapping">
								<property name="pattern" value="A_.*" />
								<property name="checker">
									<bean class="org.grapheco.elfinder.impl.FsSecurityCheckForAll">
										<property name="readable" value="true" />
										<property name="writable" value="true" />
									</bean>
								</property>
							</bean>
							<bean class="org.grapheco.elfinder.impl.FsSecurityCheckFilterMapping">
								<property name="pattern" value="B_.*" />
								<property name="checker">
									<bean class="org.grapheco.elfinder.impl.FsSecurityCheckForAll">
										<property name="readable" value="true" />
										<property name="writable" value="false" />
									</bean>
								</property>
							</bean>
						</list>
					</property>
				</bean>
			</property>
		</bean>
	</property>
</bean>

A ConnectorServlet is provided for people who do not use spring framework:

<servlet>
	<servlet-name>elfinder-connector-servlet</servlet-name>
	<servlet-class>org.grapheco.elfinder.servlet.ConnectorServlet
	</servlet-class>
</servlet>
<servlet-mapping>
	<servlet-name>elfinder-connector-servlet</servlet-name>
	<url-pattern>/elfinder-servlet/connector</url-pattern>
</servlet-mapping>

If you want to customize behavior of ConnectorServlet(see https://github.com/bluejoe2008/elfinder-2.x-servlet/blob/0.9/src/main/java/cn/bluejoe/elfinder/servlet/ConnectorServlet.java), you may need to create a derivided servlet class based on ConnectorServlet.

features

  • easy to use: just define a servlet in your web.xml, or configure the XML file in spring IOC format, and then start your web application
  • easy to import: an artifact on the central repostory is provided, use maven to manage the dependency
  • logic file views: a local file system is not necessary, you can define your FsService
  • easy to personalize: different file views are allowed for different users, just provide a custom FsServiceFactory
  • easy to modify and extend: provide your own CommandExecutors to respond new commands

Command, CommandExecutor, CommandExecutorManager

elfinder-2.x-servlet implements file management commands including:

  • DIM
  • DUPLICATE
  • FILE
  • GET
  • LS
  • MKDIR
  • MKFILE
  • OPEN
  • PARENT
  • PASTE
  • PUT
  • RENAME
  • RM
  • SEARCH
  • SIZE
  • TMB
  • TREE
  • UPLOAD(CHUNK supported!!!)

Each command corresponds to a CommandExecutor class, for example, the TREE command is implemented by the class TreeCommandExecutor(see https://github.com/bluejoe2008/elfinder-2.x-servlet/src/main/java/cn/bluejoe/elfinder/controller/executors/TreeCommandExecutor.java). Users can modify existing class or entend new executor class by following this naming rule.

Furthermore, this rule can even be modified via setting the commandExecutorFactory in elfinder-servlet.xml, in which default factory is DefaultCommandExecutorFactory(see https://github.com/bluejoe2008/elfinder-2.x-servlet/src/main/java/cn/bluejoe/elfinder/controller/executor/DefaultCommandExecutorFactory.java). A CommandExecutorFactory tells how to locate the command executor(TreeCommandExecutor as an example) by a given command name("TREE" as an example), it is designed as an interface:

public interface CommandExecutorFactory
{
	CommandExecutor get(String commandName);
}

FsItem, FsVolume, FsService, FsServiceFactory

Each file is represented as a FsItem. And the root of a file is represented as a FsVolume. A FsVolume tells parent-children relations between all FsItems and implements all file operation (for example, create/delete).

A FsService may have many FsVolumes. Users can create a FsService via a FsServiceFactory:

public interface FsServiceFactory
{
	FsService getFileService(HttpServletRequest request, ServletContext servletContext);
}

A simple (and stupid) StaticFsServiceFactory is provided in https://github.com/bluejoe2008/elfinder-2.x-servlet/src/main/java/cn/bluejoe/elfinder/impl/StaticFsServiceFactory.java, which always returns a fixed FsService, despite of whatever it is requested. However, sometimes a FsService should be constructed dynamically according to current Web request. For example, users may own separated file spaces in a network disk service platform, in this case, getFileService() get user principal from current request and offers him/her different file view.

Версии библиотеки

Версия
1.4