温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

springboot2.0中怎么利用fastdfs实现文件分布式上传

发布时间:2021-07-23 16:57:33 来源:亿速云 阅读:116 作者:Leah 栏目:编程语言

这篇文章给大家介绍springboot2.0中怎么利用fastdfs实现文件分布式上传,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。

1. 引入依赖

在父工程中,我们已经管理了依赖,版本为:

<fastDFS.client.version>1.26.7</fastDFS.client.version>

因此,这里我们直接在工程的pom.xml中引入坐标即可:

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

@Configuration@Import(FdfsClientConfig.class)// 解决jmx重复注册bean的问题@EnableMBeanExport(registration = RegistrationPolicy.IGNORE_EXISTING)public class FastClientImporter {}

2. 在application.yml文件中编写FastDFS属性

fdfs: so-timeout: 1501 # 超时时间 connect-timeout: 601 # 连接超时时间 thumb-image: # 缩略图  width: 60  height: 60 tracker-list: # tracker地址:你的虚拟机服务器地址+端口(默认是22122)  - 192.168.0.22:22122

3. 测试

package com.leyou.upload.test;import com.github.tobato.fastdfs.domain.fdfs.StorePath;import com.github.tobato.fastdfs.domain.fdfs.ThumbImageConfig;import com.github.tobato.fastdfs.service.FastFileStorageClient;import org.junit.Test;import org.junit.runner.RunWith;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.boot.test.context.SpringBootTest;import org.springframework.test.context.junit4.SpringRunner;import java.io.File;import java.io.FileInputStream;import java.io.FileNotFoundException;/** * @author john * @date 2019/12/6 - 15:09 */@SpringBootTest@RunWith(SpringRunner.class)public class FastDFSTest {  @Autowired  private FastFileStorageClient storageClient;  @Autowired  private ThumbImageConfig thumbImageConfig;  @Test  public void testUpload() throws FileNotFoundException {    // 要上传的文件    File file = new File("D:\\imooc\\project\\images\\1.jpg");    // 上传并保存图片,参数:1-上传的文件流 2-文件的大小 3-文件的后缀 4-可以不管他    StorePath storePath = this.storageClient.uploadFile(        new FileInputStream(file), file.length(), "jpg", null);    // 带分组的路径    System.out.println(storePath.getFullPath());    // 不带分组的路径    System.out.println(storePath.getPath());  }  @Test  public void testUploadAndCreateThumb() throws FileNotFoundException {    File file = new File("D:\\imooc\\project\\images\\2.jpg");    // 上传并且生成缩略图    StorePath storePath = this.storageClient.uploadImageAndCrtThumbImage(        new FileInputStream(file), file.length(), "png", null);    // 带分组的路径    System.out.println(storePath.getFullPath());    // 不带分组的路径    System.out.println(storePath.getPath());    // 获取缩略图路径    String path = thumbImageConfig.getThumbImagePath(storePath.getPath());    System.out.println(path);  }}

关于springboot2.0中怎么利用fastdfs实现文件分布式上传就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI