目录
- SpringBoot整合FastDFS
- Java客户端/依赖
- 常用api接口解释
- 1.uploadFile
- 参数
- 返回值
- 2.uploadSlaveFile
- 参数
- 返回值
- 3.getMetadata
- 参数
- 返回值
- 4.overwriteMetadata
- 参数:
- 返回值:无
- 5.mergeMetadata
- 参数:
- 返回值:无
- 6.queryFileInfo
- 参数:
- 返回值
- 7.deleteFile
- 参数:
- 返回值:无
- 8.downloadFile
- 参数
- 返回值
- 9.downloadFile
- 参数
- 返回值
- 代码测试
- yml配置
- 工具类
- 上传
- Controller
- 测试
- 下载
- Controller
- 测试
SpringBoot整合FastDFS
Java客户端/依赖
<dependency>
<groupId>com.github.tobato</groupId>
<artifactId>fastdfs-client</artifactId>
<version>1.27.2</version>
</dependency>
常用api接口解释
1.uploadFile
uploadFile(String groupName, InputStream inputStream, long fileSize, String fileExtName)
参数
- groupName:上传文件所属的组名。
- inputStream:输入流对象,指向要上传的文件内容。
- fileSize:上传文件的大小,单位为字节。
- fileExtName:上传文件的扩展名。
返回值
返回值:一个 StorePath 对象,其中封装文件的路径和 store 节点的地址。
2.uploadSlaveFile
uploadSlaveFile(String groupName, String masterFilename, InputStream inputStream, long fileSize, String prefixName, String fileExtName)
参数
- groupName:文件上传到的组名。
- masterFilename:主文件的名称。
- inputStream:从文件的输入流对象。
- fileSize:上传从文件的大小,单位为字节。
- prefixName: 从文件名前缀
- fileExtName:从文件的扩展名
返回值
返回值:一个 StorePath 对象,表示成功上传后从文件存储的路径信息。
3.getMetadata
getMetadata(String groupName, String path)
参数
- groupName:文件所属的分组名。
- path:文件的在 FastDFS 存储中真实的路径。
返回值
返回值:Set 集合,其中包含多组 metadata 信息。每一条 metadata 是 k-v 形式的键值对。如果没有找到对应的 metadata 信息,则返回一个空的集合。
4.overwriteMetadata
overwriteMetadata(String groupName, String path, Set
参数:
- groupName:文件所属的分组名。
- path:文件在 FastDFS 存储中真实的路径。
- metaDataSet:要覆盖的新的 metadata 集合。
返回值:无
5.mergeMetadata
mergeMetadata(String groupName, String path, Set
参数:
- groupName:文件所属的分组名。
- path:文件在 FastDFS 存储中真实的路径。
- metaDataSet:待合并的metadata集合。
返回值:无
6.queryFileInfo
queryFileInfo(String groupName, String path)
参数:
- groupName:文件所属的组名。
- path:文件在 FastDFS 存储中真实的路径。
返回值
返回值:一个 FileInfo 对象,包含了文件的元数据信息。
7.deleteFile
deleteFile(String groupName, String path)
参数:
- groupName:文件所属的组名。
- path:文件在 FastDFS 存储中真实的路径。
返回值:无
8.downloadFile
downloadFile(String groupName, String path, DownloadCallback callback)
参数
- groupName:文件所属的组名。
- path:文件在 FastDFS 存储中真实的路径。
- callback:下载回调接口对象。
返回值
返回值:一个泛型值对象 T,表示经过回调方法处理后的结果。
9.downloadFile
downloadFile(String groupName, String path, long fileOffset, long fileSize, DownloadCallback callback)
参数
- groupName:文件所属的组名。
- path:文件在 FastDFS 存储中真实的路径。
- fileOffset:文件偏移量,从哪个地方开始下载。
- fileSize:要下载的文件大小。
- callback:下载回调接口对象。
返回值
返回值:一个泛型值对象 T,表示经过回调方法处理后的结果。
代码测试
yml配置
fdfs:
# 超时时间
connect_timeout: 5000
# 读取时间
so_timeout: 30000
# 服务地址列表
tracker-list: 192.168.29.31:22122
# 解决限制文件大小
spring:
servlet:
multipart:
max-request-size: 1TB
max-file-size: 1TB
工具类
package com.zjl.util;
import com.github.tobato.fastdfs.domain.fdfs.StorePath;
import com.github.tobato.fastdfs.domain.proto.storage.DownloadByteArray;
import com.github.tobato.fastdfs.service.FastFileStorageClient;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.http.HttpHeaders;
import org.springframework.http.HttpStatus;
import org.springframework.http.MediaType;
import org.springframework.http.ResponseEntity;
import org.springframework.stereotype.Component;
import org.springframework.web.multipart.MultipartFile;
import javax.annotation.Resource;
import java.io.IOException;
import java.nio.charset.StandardCharsets;
/**
* @author: zjl
* @datetime: 2024/4/7
* @desc:
*/
@Component
public class FastdfsUtil {
@Resource
private FastFileStorageClient storageClient;
/**
* 上传
*
* @param file
* @return
*/
public String upload(MultipartFile file) {
// 获取文件名
String filename = file.getOriginalFilename();
// 得到文件扩展名
String extName = filename.substring(filename.lastIndexOf(".") + 1);
StorePath storePath = null;
try {
// 上传
storePath = storageClient.uploadFile(file.getInputStream(), file.getSize(), extName, null);
// 这个getFullPath是fastdfs返回的id,可通过这个实现图片浏览、视频播放、文件下载等操作
return storePath.getFullPath();
} catch (IOException e) {
throw new RuntimeException(e);
}
}
/**
* 下载文件(写二进制流)
* @param path
* @return
*/
public ResponseEntity<byte[]> download(String fileName ,String path,HttpServletRequest request) throws Exception {
StorePath storePath = StorePath.parseFromUrl(path);
String substring = path.substring(path.lastIndexOf("."));
byte[] data = storageClient.downloadFile(storePath.getGroup(), storePath.getPath(), new DownloadByteArray());
fileName = this.getFilename(request,fileName);
HttpHeaders httpHeaders = new HttpHeaders();
// 设置下载响应类型以及文件名
httpHeaders.setContentType(MediaType.APPLICATION_OCTET_STREAM);
httpHeaders.setContentDispositionFormData("attachment",fileName+substring );
return new ResponseEntity<>(data,httpHeaders, HttpStatus.OK);
}
//解决中文下载问题
public String getFilename(HttpServletRequest request, String filename) throws Exception {
//ie浏览器的编码格式
String[] IEBrowserWords = {"MSIE","Trident","Edge"};
String userAgent = request.getHeader("User-Agent");
for (String ieBrowserWord : IEBrowserWords) {
if(userAgent.contains(ieBrowserWord)){
return URLEncoder.encode(filename,"UTF-8");
}
}
//其他浏览器就采用这种编码格式
return new String(filename.getBytes("UTF-8"),"ISO-8859-1");
}
}
上传
Controller
package com.zjl.controller;
import com.zjl.util.FastdfsUtil;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.multipart.MultipartFile;
import javax.annotation.Resource;
/**
* @author: zjl
* @datetime: 2024/4/7
* @desc:
*/
@RestController
public class MyFileController {
@Resource
private FastdfsUtil fastdfsUtil;
@PostMapping("/upload")
public String upload(MultipartFile file){
return fastdfsUtil.upload(file);
}
}
测试
直接访问这个地址:http://192.168.29.31:8888/group1/M00/00/00/wKgdH2YSNj2ABnBCAAEQeS5bVeM384.jpg
下载
Controller
@GetMapping("/download")
public ResponseEntity<byte[]> download(HttpServletRequest request) throws Exception {
//假设这是从其他业务层获取的文件路径
String filePath = "group1/M00/00/00/wKgdH2YSNj2ABnBCAAEQeS5bVeM384.jpg";
String fileName = "Spring权限管理";
return fastdfsUtil.download(fileName,filePath,request);
}
测试