# dwarfeng-ftp
**Repository Path**: dwarfeng/dwarfeng-ftp
## Basic Information
- **Project Name**: dwarfeng-ftp
- **Description**: 基于 subgrade 框架的 ftp 处理器
- **Primary Language**: Java
- **License**: Apache-2.0
- **Default Branch**: master
- **Homepage**: None
- **GVP Project**: No
## Statistics
- **Stars**: 3
- **Forks**: 1
- **Created**: 2022-01-27
- **Last Updated**: 2025-06-01
## Categories & Tags
**Categories**: Uncategorized
**Tags**: None
## README
# dwarfeng-ftp
Dwarfeng(赵扶风)的 FTP 服务,基于 `subgrade` 项目,在 `commons-io` 的基础上做了进一步封装,目前用于多个个人项目。
---
## 特性
1. Subgrade 架构支持。
2. 保存文件时创建不存在的目录。
3. 中文编码支持。
4. 自动保持连接。
5. 自动保持连接与断线重连。
6. 打开文件的输入流/输出流。
7. 文件重命名。
8. 清空目录。
运行 `src/test` 下的示例以观察全部特性。
| 示例类名 | 说明 |
|------------------------------------------------|--------|
| com.dwarfeng.ftp.example.ProcessExample | 流程示例 |
| com.dwarfeng.ftp.example.StreamExample | 流的使用示例 |
| com.dwarfeng.ftp.example.ListFileExample | 列出文件示例 |
| com.dwarfeng.ftp.example.RenameFileExample | 列出文件示例 |
| com.dwarfeng.ftp.example.ClearDirectoryExample | 清空目录示例 |
| com.dwarfeng.ftp.example.CopyFileExample | 复制文件示例 |
| com.dwarfeng.ftp.example.DescFileExample | 描述文件示例 |
## 文档
该项目的文档位于 [docs](./docs) 目录下,包括:
### wiki
wiki 为项目的开发人员为本项目编写的详细文档,包含不同语言的版本,主要入口为:
1. [简介](./docs/wiki/zh_CN/Introduction.md) - 镜像的 `README.md`,与本文件内容基本相同。
2. [目录](./docs/wiki/zh_CN/Contents.md) - 文档目录。
## 测试
该项目针对多个 FTP 服务端进行了测试,测试结果如下:
| FTP 服务器类型 | 测试结果 |
|-----------------------|------|
| vsftpd | 通过 |
| Windows 10 内置 FTP 服务器 | 通过 |
## 安装说明
1. 下载源码。
使用 git 进行源码下载。
```shell
git clone git@github.com:DwArFeng/dwarfeng-ftp.git
```
对于中国用户,可以使用 gitee 进行高速下载。
```shell
git clone git@gitee.com:dwarfeng/dwarfeng-ftp.git
```
2. 项目安装。
进入项目根目录,执行 maven 命令
```shell
mvn clean source:jar install
```
3. 项目引入。
在项目的 pom.xml 中添加如下依赖:
```xml
com.dwarfeng
dwarfeng-ftp
${dwarfeng-ftp.version}
```
4. enjoy it.
## 如何使用
1. 运行 `src/test` 下的 `Example` 以观察全部特性。
2. 观察项目结构,将其中的配置运用到其它的 subgrade 项目中。
### 单例模式
加载 `com.dwarfeng.ftp.configuration.SingletonConfiguration`,即可获得单例模式的 `FtpHandler`。
在项目的 `application-context-scan.xml` 中追加 `com.dwarfeng.ftp.configuration` 包中全部 bean 的扫描,示例如下:
```xml
```
或者只扫描 `com.dwarfeng.ftp.configuration` 包中的 `SingletonConfiguration`,示例如下:
```xml
```
### 多实例模式
不使用包扫描,使用 xml 或者配置类生成 `FtpHandlerImpl` 实例。
在项目的 `bean-definition.xml` 中追加配置,示例如下:
```xml
```
### 任意数量的实例模式
自行设计 `FtpHandler` 的工厂类,调用相关工厂方法生成 `FtpHandlerImpl` 实例。
需要注意的是:生成的 `FtpHandlerImpl` 在使用之前需要调用 `FtpHandlerImpl#start()` 启动处理器;同时在使用完毕之后,
需要调用 `FtpHandlerImpl#stop()` 关闭处理器。