文件上传是每个项目中必不可少的功能,随着开发的项目越来越多,我们可以把文件上传进行多种适配,满足不同场合、不同环境的需要,闲话少叙,奉上实现方法。
本地文件适配:
1、配置文件
# 本地文件上传
file:
# 访问地址
domain: http://127.0.0.1:9090
# 本地存放的路径地址
path: D:/localFile/uploadPath
# 映射地址
prefix: /statics
2、增加路径映射,继承WebMvcConfigurer
,重写addResourceHandlers
,在registry
里面配置访问路径和映射到的服务器本地路径。
@Override
public void addResourceHandlers(ResourceHandlerRegistry registry)
{
/** 本地文件上传路径 */
registry.addResourceHandler(localFilePrefix + "/**")
.addResourceLocations("file:" + localFilePath + File.separator);
}
3、上传文件,在LocalSysFileServiceImpl中重写uploadFile方法。
@Override
public String uploadFile(MultipartFile file) throws Exception
{
String name = FileUploadUtils.upload(localFilePath, file);
String url = domain + localFilePrefix + name;
return url;
}
MinIO存储:
1、配置文件
# Minio配置
minio:
url: http://127.0.0.1:9000
# 账号
accessKey: minioadmin
# 密码
secretKey: minioadmin
# MinIO桶名字
bucketName: myBucket
2、上传文件,在MinioSysFileServiceImpl中重写uploadFile方法。
@Override
public String uploadFile(MultipartFile file) throws Exception
{
String fileName = FileUploadUtils.extractFilename(file);
PutObjectArgs args = PutObjectArgs.builder()
.bucket(minioConfig.getBucketName())
.object(fileName)
.stream(file.getInputStream(), file.getSize(), -1)
.contentType(file.getContentType())
.build();
client.putObject(args);
return minioConfig.getUrl() + "/" + minioConfig.getBucketName() + "/" + fileName;
}
FastDfs存储:
1、配置文件
# FastDFS配置
fdfs:
domain: http://8.129.231.12
soTimeout: 3000
connectTimeout: 2000
trackerList: 8.129.231.12:22122
2、上传文件,在FastDfsSysFileServiceImpl中重写uploadFile方法。
@Override
public String uploadFile(MultipartFile file) throws Exception
{
StorePath storePath = storageClient.uploadFile(file.getInputStream(), file.getSize(),
FilenameUtils.getExtension(file.getOriginalFilename()), null);
return domain + "/" + storePath.getFullPath();
}
最后通过把注解@Primary标注在对应的Service类上来标识采用哪种方式存储文件。源码后续提供。