data:image/s3,"s3://crabby-images/03708/037080467a813875fb54f9f39e21c26488d790e1" alt="logo"
原名 X Spring File Storage 现已捐赠至 dromara 开源组织
x-file-storage.dromara.org | x-file-storage.xuyanwu.cn | spring-file-storage.xuyanwu.cn
📚简介
一行代码将文件存储到本地、FTP、SFTP、WebDAV、阿里云 OSS、华为云 OBS、七牛云 Kodo、腾讯云 COS、百度云 BOS、又拍云 USS、MinIO、 Amazon S3、GoogleCloud Storage、金山云 KS3、美团云 MSS、京东云 OSS、天翼云 OOS、移动 云EOS、沃云 OSS、 网易数帆 NOS、Ucloud US3、青云 QingStor、平安云 OBS、首云 OSS、IBM COS、其它兼容 S3 协议的存储平台。查看 所有支持的存储平台
💡 通过 WebDAV 连接到 Alist 后,可以使用百度网盘、天翼云盘、阿里云盘、迅雷网盘等常见存储服务,查看 Alist 支持的存储平台
GitHub:github.com/dromara/x-f…
Gitee:gitee.com/dromara/x-f…
文档1:x-file-storage.dromara.org
文档2:x-file-storage.xuyanwu.cn
文档3:spring-file-storage.xuyanwu.cn
📜更新内容
- 更改项目名、更改包名、优化项目结构
- 新增直接读取 HttpServletRequest 的流进行上传,文件不落盘,速度更快
- 新增支持 Metadata 元数据
- 优化 ACL 异常处理
- 优化文件删除逻辑
- 修复 Amazon S3 上传文件偶现 ResetException 问题
- 捐赠至 dromara 开源社区
项目依赖的变化
2.0.0 之前的版本
<dependency>
<groupId>cn.xuyanwu</groupId>
<artifactId>spring-file-storage</artifactId>
<version>1.0.3</version>
</dependency>
2.0.0 及以后的版本
<dependency>
<groupId>org.dromara.x-file-storage</groupId>
<artifactId>x-file-storage-spring</artifactId>
<version>2.0.0</version>
</dependency>
配置参数的变化
2.0.0 之前的版本
spring:
file-storage: #文件存储配置
default-platform: huawei-obs-1 #默认使用的存储平台
thumbnail-suffix: ".min.jpg" #缩略图后缀,例如【.min.jpg】【.png】
#对应平台的配置写在这里,注意缩进要对齐
2.0.0 及以后的版本
dromara:
x-file-storage: #文件存储配置
default-platform: huawei-obs-1 #默认使用的存储平台
thumbnail-suffix: ".min.jpg" #缩略图后缀,例如【.min.jpg】【.png】
#对应平台的配置写在这里,注意缩进要对齐
包名的变化
2.0.0 之前的版本
cn.xuyanwu.spring.file.storage
cn.xuyanwu.spring.file.storage.spring
2.0.0 及以后的版本
org.dromara.x.file.storage.core
org.dromara.x.file.storage.spring
📦使用
点击 快速入门 查看全部存储平台的使用方法!
🔧 配置
这里以阿里云 OSS 为例,pom.xml
引入本项目,这里默认是 SpringBoot
环境,其它环境参考 脱离 SpringBoot 单独使用
<!-- 引入本项目 -->
<dependency>
<groupId>org.dromara.x-file-storage</groupId>
<artifactId>x-file-storage-spring</artifactId>
<version>2.0.0</version>
</dependency>
<!-- 引入 阿里云 OSS SDK,如果使用其它存储平台,就引入对应的 SDK-->
<dependency>
<groupId>com.aliyun.oss</groupId>
<artifactId>aliyun-sdk-oss</artifactId>
<version>3.16.1</version>
</dependency>
application.yml
配置文件中添加以下基础配置
dromara:
x-file-storage: #文件存储配置
default-platform: aliyun-oss-1 #默认使用的存储平台
aliyun-oss:
- platform: aliyun-oss-1 # 存储平台标识
enable-storage: true# 启用存储
access-key: ??
secret-key: ??
end-point: ??
bucket-name: ??
domain: ?? # 访问域名,注意“/”结尾,例如:https://abc.oss-cn-shanghai.aliyuncs.com/
base-path: test/ # 基础路径
🔨编码
在启动类上加上@EnableFileStorage
注解
@EnableFileStorage
@SpringBootApplication
public class SpringFileStorageTestApplication {
public static void main(String[] args) {
SpringApplication.run(SpringFileStorageTestApplication.class,args);
}
}
✨开始上传
支持 File、MultipartFile、byte[]、InputStream、URL、URI、String、HttpServletRequest,大文件会自动分片上传。如果想支持更多方式,请阅读 文件适配器 章节
@RestController
public class FileDetailController {
@Autowired
private FileStorageService fileStorageService;//注入实列
/**
* 上传文件
*/
@PostMapping("/upload")
public FileInfo upload(MultipartFile file) {
//只需要这一行代码即可上传成功
return fileStorageService.of(file).upload();
}
/**
* 上传文件,成功返回文件 url
*/
@PostMapping("/upload2")
public String upload2(MultipartFile file) {
FileInfo fileInfo = fileStorageService.of(file)
.setPath("upload/") //保存到相对路径下,为了方便管理,不需要可以不写
.setObjectId("0") //关联对象id,为了方便管理,不需要可以不写
.setObjectType("0") //关联对象类型,为了方便管理,不需要可以不写
.putAttr("role","admin") //保存一些属性,可以在切面、保存上传记录、自定义存储平台等地方获取使用,不需要可以不写
.upload();//将文件上传到对应地方
return fileInfo == null ? "上传失败!" : fileInfo.getUrl();
}
/**
* 上传图片,成功返回文件信息
* 图片处理使用的是 https://github.com/coobird/thumbnailator
*/
@PostMapping("/upload-image")
public FileInfo uploadImage(MultipartFile file) {
return fileStorageService.of(file)
.image(img -> img.size(1000,1000))//将图片大小调整到 1000*1000
.thumbnail(th -> th.size(200,200))//再生成一张 200*200 的缩略图
.upload();
}
/**
* 上传文件到指定存储平台,成功返回文件信息
*/
@PostMapping("/upload-platform")
public FileInfo uploadPlatform(MultipartFile file) {
return fileStorageService.of(file)
.setPlatform("aliyun-oss-1")//使用指定的存储平台
.upload();
}
/**
* 直接读取 HttpServletRequest 中的文件进行上传,成功返回文件信息
* 使用这种方式有些注意事项,请查看文档 基础功能-上传 章节
*/
@PostMapping("/upload-request")
public FileInfo uploadPlatform(HttpServletRequest request) {
return fileStorageService.of(request).upload();
}
}
🎨其它操作
//手动构造文件信息,可用于其它操作
FileInfo fileInfo = new FileInfo()
.setPlatform("huawei-obs-1")
.setBasePath("test/")
.setPath("aa/")
.setFilename("image.png")
.setThFilename("image.png.min.jpg");
//文件是否存在
boolean exists = fileStorageService.exists(fileInfo);
//下载
byte[] bytes = fileStorageService.download(fileInfo).bytes();
//删除
fileStorageService.delete(fileInfo);
//其它更多操作
如果将文件记录保存到数据库中,还可以更方便的根据 URL 进行操作了,详情请阅读 保存上传记录 章节
//直接从数据库中获取 FileInfo 对象,更加方便执行其它操作
FileInfo fileInfo = fileStorageService.getFileInfoByUrl("https://abc.def.com/test/aa/image.png");
//文件是否存在
boolean exists = fileStorageService.exists("https://abc.def.com/test/aa/image.png");
//下载
byte[] bytes = fileStorageService.download("https://abc.def.com/test/aa/image.png").bytes();
//删除
fileStorageService.delete("https://abc.def.com/test/aa/image.png");
//其它更多操作
点击 快速入门 查看全部存储平台的使用方法!
🚀Dromara成员项目
data:image/s3,"s3://crabby-images/0ae4b/0ae4bf086229fa671e21acbb561f0d89321c9557" alt="TLog"
data:image/s3,"s3://crabby-images/8f028/8f028340775444b688017257819b3859cce9e4a1" alt="liteFlow"
data:image/s3,"s3://crabby-images/163f0/163f0b389ffceb6bd790574d2a100f8c0e4a334b" alt="hutool"
data:image/s3,"s3://crabby-images/f6baa/f6baa427c4ccf7b7deb5f68e057ccd7ca80c1720" alt="sa-token"
data:image/s3,"s3://crabby-images/f9f17/f9f1736c9730e704cb5b45bfbfbedc50b8b8e5a9" alt="hmily"
data:image/s3,"s3://crabby-images/f76b8/f76b8ee8adf6ce1ffb598d8552ee0f5ceb6b505e" alt="Raincat"
data:image/s3,"s3://crabby-images/29022/29022898bbdbe43cbd8dcf6a20371561f6d4634f" alt="myth"
data:image/s3,"s3://crabby-images/8d60c/8d60c16ae3d605507f551541e39e143c8194d639" alt="cubic"
data:image/s3,"s3://crabby-images/09e0e/09e0e743ecbbae2e8aed4d71c4b2d92f4ba52c5c" alt="maxkey"
data:image/s3,"s3://crabby-images/1beab/1beab8646cb0b13ca945e09cbb55859fd75fac18" alt="forest"
data:image/s3,"s3://crabby-images/59f22/59f2236cc5ecf28f7b4b69dbedbfaf556fdd17bb" alt="jpom"
data:image/s3,"s3://crabby-images/f4d1a/f4d1aa607faf9d80805387e63735b4f63e1254a8" alt="sureness"
data:image/s3,"s3://crabby-images/6b3d5/6b3d5e8113a13421ec22374de6968d896e1fa153" alt="easy-es"
data:image/s3,"s3://crabby-images/1c6cc/1c6ccdf61987580540bdcb644e2e5e4bbbad172d" alt="northstar"
data:image/s3,"s3://crabby-images/9d60d/9d60dc780819ada405f48b29bb85c60bd5498de2" alt="hertzbeat"
data:image/s3,"s3://crabby-images/398ba/398ba53517d25d9be1072c1124f00e7a830ccf25" alt="fast-request"
data:image/s3,"s3://crabby-images/f170d/f170d5ef83f8c52a13d9aa0b1753497b47348d4f" alt="mendmix"
data:image/s3,"s3://crabby-images/fcda5/fcda52ad08b004b5c4b958ea1268724333bc5720" alt="koalas-rpc"
data:image/s3,"s3://crabby-images/55758/55758ab192da63714c573bef632a9aa275b6f8a9" alt="gobrs-async"
data:image/s3,"s3://crabby-images/93112/9311236c77f791b8a8508ba0b1b96f1d33752b66" alt="dynamic-tp"
data:image/s3,"s3://crabby-images/e4b05/e4b056ca7dd01fb71e5e286378f307b25942a48b" alt="x-easypdf"
data:image/s3,"s3://crabby-images/4ac27/4ac27de055e1300e15c2b2d67d6151bff6029092" alt="image-combiner"
data:image/s3,"s3://crabby-images/18813/18813e47909e47c7311e3f0a0fe6b22ab023ae92" alt="dante-cloud"
data:image/s3,"s3://crabby-images/0c004/0c004bb48de977e898ba64a71c637857bea053be" alt="go-view"
data:image/s3,"s3://crabby-images/18328/1832815fadeae153a94a70b0a3d71ee864902157" alt="lamp-cloud"
data:image/s3,"s3://crabby-images/c5b7b/c5b7bae601a6ce8a40d8b4b3b1cedfe90fd7fe6b" alt="redis-front"
data:image/s3,"s3://crabby-images/d7405/d7405a0a0851f1ee0fe89a48d5086e3af7083194" alt="electron-egg"
data:image/s3,"s3://crabby-images/d2ea3/d2ea37546e1d76001133dafa708cfce4a4f42b68" alt="open-capacity-platform"
data:image/s3,"s3://crabby-images/cfb5c/cfb5c248ce55601ba563d97d6c219ed0d258a6c1" alt="Easy-Trans"
data:image/s3,"s3://crabby-images/df7fd/df7fd4dcfcf12d5b5adda0fc6e2315bb26c1a715" alt="neutrino-proxy"
data:image/s3,"s3://crabby-images/12275/122751899b58eee1550f0c26314a2ed8af84cff3" alt="chatgpt"
data:image/s3,"s3://crabby-images/2687c/2687cc70a78ab31e97adb5044d9403908a2ca9aa" alt="zyplayer-doc"
data:image/s3,"s3://crabby-images/d4dfc/d4dfc7bdabd425907abfb9c3845070e157fadaed" alt="payment-spring-boot"
data:image/s3,"s3://crabby-images/68b7e/68b7e52c718d816ef1c44f6af8b71e2f66c7daef" alt="j2eefast"
data:image/s3,"s3://crabby-images/c81ad/c81ad15beda76640da806ddd1876d5060f2fcf9f" alt="data-compare"
data:image/s3,"s3://crabby-images/2c359/2c3597793865462c1a920258175e6dd994bafb51" alt="open-giteye-api"
data:image/s3,"s3://crabby-images/93039/930390635d2b884ed3027c850eca193f8c9c8697" alt="RuoYi-Vue-Plus"
data:image/s3,"s3://crabby-images/9e364/9e364ab52ae87b9b6ddc83e693da21cfa66405f6" alt="RuoYi-Cloud-Plus"
data:image/s3,"s3://crabby-images/812ae/812ae4007c296e3246a78a031935f9127b1d777f" alt="stream-query"
data:image/s3,"s3://crabby-images/7a8f1/7a8f1c750829edfc6f6aaf99ad19c9aa1f0b52e3" alt="sms4j"
data:image/s3,"s3://crabby-images/a3cbd/a3cbd723fee31df4a5cd4f52cc704eb37ba4b3c0" alt="cloudeon"
data:image/s3,"s3://crabby-images/86aa4/86aa4cc7c72e69e228caa1639db1b202fac7eec1" alt="hodor"
data:image/s3,"s3://crabby-images/18672/18672529f6f795ad0794cbd9349120e2716edd91" alt="test-hub"
data:image/s3,"s3://crabby-images/fd3bf/fd3bfabfbea808aba6f39523eb0b0a35456b1a0f" alt="disjob"
data:image/s3,"s3://crabby-images/cae2b/cae2b17100e3b6393a7c3915e4c29e7c4fd01619" alt="binlog4j"
data:image/s3,"s3://crabby-images/162c9/162c9149e4613171900e85ab63cea2366e1284bf" alt="yft-design"
data:image/s3,"s3://crabby-images/ceab5/ceab52c9c3e1ade353ee44465f5ceffbfe9ce7ce" alt="x-file-storage"
data:image/s3,"s3://crabby-images/f40a2/f40a2059f47b852ff057d742f4e24d102aad29ef" alt="dromara"
为往圣继绝学,一个人或许能走的更快,但一群人会走的更远。