Springboot集成fastDFS

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Springboot集成fastDFS相关的知识,希望对你有一定的参考价值。

配置文件

配置fdfs_client.conf配置文件

# 连接超时时间,针对socket套接字函数connect,默认为30秒
connect_timeout=30000
# 网络通讯超时时间,默认是60秒
network_timeout=60000
tracker_server = 47.98.159.15:22122

导入依赖

<dependency>
            <groupId>org.csource</groupId>
            <artifactId>fastdfs-client-java</artifactId>
            <version>1.27-SNAPSHOT</version>
        </dependency>

配置客户端

package panda.data.Utils;

import org.csource.common.MyException;
import org.csource.fastdfs.*;
import org.slf4j.LoggerFactory;
import org.springframework.core.io.ClassPathResource;
import org.springframework.web.multipart.MultipartFile;

import java.io.IOException;
import java.util.stream.Stream;

/**
 * @Auther: 罗罗
 * @Description:
 */
public class FastDFSClient {
    private static org.slf4j.Logger logger = LoggerFactory.getLogger(FastDFSClient.class);

    public static String uploadImage(MultipartFile multipartFile) throws IOException, MyException {
        // 1、初始化全局配置。加载一个配置文件。
        String filePath = new ClassPathResource("fdfs_client.conf").getFile().getAbsolutePath();
        ClientGlobal.init(filePath);

        // 2、创建一个TrackerClient对象。
        TrackerClient trackerClient = new TrackerClient();
        // 3、创建一个TrackerServer对象。
        TrackerServer trackerServer = trackerClient.getConnection();
        // 4、声明一个StorageServer对象,null。
        StorageServer storageServer = null;
        // 5、获得StorageClient对象。
        StorageClient storageClient = new StorageClient(trackerServer, storageServer);
        byte[] bytes = multipartFile.getBytes();// 获得上传的二进制对象
        String[] strings = storageClient.upload_file(bytes, "jpg", null);
        Stream.of(strings).forEach(System.out::println);
        String imagurl = "http://47.98.159.35/"+strings[0]+"/"+strings[1];
        //返回值0代表删除成功
        //int result = storageClient.delete_file("group1", "M00/00/00/wKgAaFyM3fSANCgXAABMnNm0e54098.jpg");
        //System.out.println("result="+result);
        return imagurl;
    }
}
package panda.data.controller;

import org.csource.common.MyException;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.multipart.MultipartFile;
import panda.data.ResultData.ImgAttr;
import panda.data.ResultData.ResultData;
import panda.data.Utils.FastDFSClient;

import java.io.IOException;
import java.util.ArrayList;

@Controller
public class ImgController {

    @Autowired
    private ResultData resultData;
    //必须是post方式
    @PostMapping("/fileUpload")
    @ResponseBody
    public ResultData fileUpload(@RequestParam("file") MultipartFile multipartFile) throws IOException, MyException {
        String url = FastDFSClient.uploadImage(multipartFile);
        if (url.contains("group")){
            resultData.setCode(0);
            ImgAttr imgAttr = new ImgAttr(url);
            ArrayList<Object> list = new ArrayList<>();
            list.add(imgAttr);
            resultData.setData(list);
        }else {
            resultData.setCode(0);
            resultData.setData(null);
        }
        return resultData;
    }
}

结尾

本文到这里就结束了,感谢看到最后的朋友,都看到最后了,点个赞再走啊,如有不对之处还请多多指正。

以上是关于Springboot集成fastDFS的主要内容,如果未能解决你的问题,请参考以下文章

SpringBoot框架集成FastDFS分布式文件系统,实现文件路径加密处理的图片预览下载。

Springboot集成fastDFS

FastDFS与Springboot集成

FastDFS与Springboot集成

Spring Boot(十八):使用Spring Boot集成FastDFS

(二十四)ATP应用测试平台——springboot集成fastdfs上传与下载功能