SpringBoot 开发案例之整合FastDFS分布式文件系统

摘要:
版本>1.26.6<MataData.add(newMetaData(“作者”)//上载StorePathstorePath=fastFileStorageClient。uploadFile(file.getInputStream());

1、pom依赖

<!--fastdfs-->
<dependency>
    <groupId>com.github.tobato</groupId>
    <artifactId>fastdfs-client</artifactId>
    <version>1.26.6</version>
</dependency>

2、application.properties

server.port=8082
#超时时长 fdfs.so
-timeout=1500 #连接tracker服务器超时时长 fdfs.connect-timeout=600 #缩略图 fdfs.thumb-image.height=150 fdfs.thumb-image.width=150 #tracker服务配置地址列表,替换成自己服务的IP地址,支持多个 fdfs.tracker-list=192.168.206.173:22122 #文件上传配置 spring.servlet.multipart.enabled=true spring.servlet.multipart.max-file-size=10MB spring.servlet.multipart.max-request-size=20MB

3、工具类

@Component
public class FastdfsUtils
{
    public static final String DEFAULT_CHARSET = "UTF-8";

    @Autowired
    private FastFileStorageClient fastFileStorageClient;

    /**
     * 上传
     *
     * @param file
     * @return
     * @throws IOException
     */
    public StorePath upload(MultipartFile file)
        throws IOException
    {
        // 设置文件信息
        Set<MetaData> mataData = new HashSet<>();
        mataData.add(new MetaData("author", "fastdfs"));
        mataData.add(new MetaData("description", file.getOriginalFilename()));
        // 上传
        StorePath storePath = fastFileStorageClient.uploadFile(
            file.getInputStream(), file.getSize(),
            FilenameUtils.getExtension(file.getOriginalFilename()),
            null);
        return storePath;
    }

    /**
     * 删除
     *
     * @param path 例如: group1/M00/00/00/wKjOrWD45PKAY4xmAFLQaGXPnu0735.jpg
     */
    public void delete(String path)
    {
        fastFileStorageClient.deleteFile(path);
    }

    /**
     * 删除
     *
     * @param group 例如: group1
     * @param path  例如: M00/00/00/wKjOrWD45PKAY4xmAFLQaGXPnu0735.jpg
     */
    public void delete(String group, String path)
    {
        fastFileStorageClient.deleteFile(group, path);
    }

    /**
     * 文件下载
     *
     * @param path     文件路径,例如:group1/M00/00/00/wKjOrWD40JiAQNKLABO5RCqSdcQ975.jpg
     * @param filename 下载的文件命名
     * @return
     */
    public void download(String path, String filename, HttpServletResponse response)
        throws IOException
    {
        // 获取文件
        StorePath storePath = StorePath.parseFromUrl(path);
        //如果名字是空的 下载文件名以存储的为准
        if (StringUtils.isBlank(filename))
        {
            filename = FilenameUtils.getName(storePath.getPath());
        }
        else
        {
            filename = filename + storePath.getPath().substring(storePath.getPath().lastIndexOf("."));
        }
        byte[] bytes =
            fastFileStorageClient.downloadFile(storePath.getGroup(), storePath.getPath(), new DownloadByteArray());
        response.reset();
        response.setContentType("applicatoin/octet-stream");
        response.setHeader("Content-Disposition", "attachment;filename=" + URLEncoder.encode(filename, "UTF-8"));
        ServletOutputStream out = response.getOutputStream();
        out.write(bytes);
        out.close();
    }
}

4、controller层代码

@RestController
public class FileController
{
    private static final Logger LOGGER = LoggerFactory.getLogger(FileController.class);

    @Resource
    private FastdfsUtils fastdfsUtils;

    @PostMapping("uploadFile")
    private StorePath uploadFile(MultipartFile file)
    {
        StorePath storePath = null;
        try
        {
            storePath = fastdfsUtils.upload(file);
        }
        catch (Exception e)
        {
            e.printStackTrace();
            LOGGER.info("服务异常");
        }
        return storePath;
    }

    @PostMapping("deleteByPath")
    private String deleteByPath(String path)
    {
        try
        {
            fastdfsUtils.delete(path);
        }
        catch (Exception e)
        {
            e.printStackTrace();
            LOGGER.info("删除异常");
        }
        return "success";
    }

    @GetMapping("downloadFile")
    private void downloadFile(String path, String name, HttpServletResponse response)
    {
        try
        {
            fastdfsUtils.download(path, name, response);
        }
        catch (Exception e)
        {
            e.printStackTrace();
            LOGGER.info("下载异常");
        }
    }
}

免责声明:文章转载自《SpringBoot 开发案例之整合FastDFS分布式文件系统》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇ASCII 码表对照Thinkpad USB 经典键盘使用体验下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

浅析前端常见文件下载的9种场景:Blob基础知识/组成/Blob URL、a标签下载、showSaveFilePicker API下载(兼容性差)、FileSaver.js库下载、Zip下载(JSZip库)、附件形式下载(设置Content-Disposition)、base64格式下载(需转为blob)、分块传输下载、HTTP范围请求下载、大文件分块并行下载

  一般在我们工作中,主要会涉及到 9 种文件下载的场景,每一种场景背后都使用不同的技术,其中也有很多细节需要我们额外注意。   在浏览器端处理文件的时候,我们经常会用到 Blob 。比如图片本地预览、图片压缩、大文件分块上传及文件下载。在浏览器端文件下载的场景中,比如我们今天要讲到的 a 标签下载、showSaveFilePicker API 下载、Z...

node中的request模块(http.get封装版)

1.下载并引入request cnpm install request --save; const request = require("request"); 2.基本使用 request({ url: url,//请求路径 method: "POST",//请求方式,默认为get headers: {//设置请求头...

java导出生成word

最近做的项目,需要将一些信息导出到word中。在网上找了好多解决方案,现在将这几天的总结分享一下。 目前来看,java导出word大致有6种解决方案:   1:Jacob是Java-COM Bridge的缩写,它在Java与微软的COM组件之间构建一座桥梁。使用Jacob自带的DLL动态链接库,并通过JNI的方式实现了在Java平台上对COM程序的调用。D...

ansible-乱

工作机制:ssh 无客户端 工作方式: 1,CMDB 2,公有云私有云API 3,使用ad-hoc 4,ansible-playbook ansible 执行命令,底层调用传输连接模块,将命令或文件传输至远程服务器的/tmp目录,远程执行,操作完后删除,返回结果。 配置文件 /etc/ansible 功能;inventory 主机信息配置 工具功能 /us...

Linux常用命令及示例(全)

NO 分类 PS1 命令名 用法及参数 功能注解1 显示目录信息 # ls ls -a 列出当前目录下的所有文件,包括以.头的隐含文件 # ls ls -l或ll 列出当前目录下文件的详细信息 # ls ls -a 显示所有文件,包含隐藏。 # ls ls -al 显示所有文件的详细信息。 2 查看路径 # pwd pwd 查看当前所在目录的绝对路经 3...

Golang 编译打包-构建集成

golang编译方式一般分为两种,一种是源码编译,另外一个是交叉编译 1.源码编译 这种方式需要在机器上安装相应的go sdk,可以参考环境部署相关的文章,这里不再叙述;我们只需要把项目代码copy到相应的机器上,然后再项目目录中,执行命令:go build ./main.go -o outdir,编译速度非常快,接着在outdir文件中即可看到编译后的二...