使用Spring Boot集成FastDFS

1、pom包配置

我们使用Spring Boot最新版本1.5.9、jdk使用1.8、tomcat8.0。

Java

加入了 fastdfs-client-java包,用来调用FastDFS相关的API。

2、配置文件

resources目录下添加 fdfs_client.conf文件

Java

配置文件设置了连接的超时时间,编码格式以及tracker_server地址等信息

3、封装FastDFS上传工具类

封装FastDFSFile,文件基础信息包括文件名、内容、文件类型、作者等。

Java

封装FastDFSClient类,包含常用的上传、下载、删除等方法。

首先在类加载的时候读取相应的配置信息,并进行初始化。

  1. static{

  2. try{

  3. String filePath =newClassPathResource("fdfs_client.conf").getFile().getAbsolutePath();;

  4. ClientGlobal.init(filePath);

  5. trackerClient =newTrackerClient();

  6. trackerServer = trackerClient.getConnection();

  7. storageServer = trackerClient.getStoreStorage(trackerServer);

  8. }catch(Exception e){

  9. logger.error("FastDFS Client Init Fail!",e);

  10. }

  11. }

文件上传

  1. publicstaticString[] upload(FastDFSFile file){

  2. logger.info("File Name: "+ file.getName()+"File Length:"+ file.getContent().length);

  3. NameValuePair[] meta_list =newNameValuePair[1];

  4. meta_list[0]=newNameValuePair("author", file.getAuthor());

  5. long startTime =System.currentTimeMillis();

  6. String[] uploadResults =null;

  7. try{

  8. storageClient =newStorageClient(trackerServer, storageServer);

  9. uploadResults = storageClient.upload_file(file.getContent(), file.getExt(), meta_list);

  10. }catch(IOException e){

  11. logger.error("IO Exception when uploadind the file:"+ file.getName(), e);

  12. }catch(Exception e){

  13. logger.error("Non IO Exception when uploadind the file:"+ file.getName(), e);

  14. }

  15. logger.info("upload_file time used:"+(System.currentTimeMillis()- startTime)+" ms");

  16. if(uploadResults ==null){

  17. logger.error("upload file fail, error code:"+ storageClient.getErrorCode());

  18. }

  19. String groupName = uploadResults[0];

  20. String remoteFileName = uploadResults[1];

  21. logger.info("upload file successfully!!!"+"group_name:"+ groupName +", remoteFileName:"+" "+ remoteFileName);

  22. return uploadResults;

  23. }

使用FastDFS提供的客户端storageClient来进行文件上传,最后将上传结果返回。

根据groupName和文件名获取文件信息。

Java

下载文件

Java

删除文件

Java

使用FastDFS时,直接调用FastDFSClient对应的方法即可。

4、编写上传控制类

从MultipartFile中读取文件信息,然后使用FastDFSClient将文件上传到FastDFS集群中。

Java

请求控制,调用上面方法 saveFile()。

Java

上传成功之后,将文件的路径展示到页面,效果图如下:

Java

在浏览器中访问此Url,可以看到成功通过FastDFS展示:

Java

这样使用Spring Boot 集成FastDFS的案例就完成了。

示例代码:https://github.com/ityouknow/spring-boot-examples

Java学习资料获取(复制下段连接至浏览器即可)

data:text/html;charset=UTF-8;base64,5p625p6E5biI5a2m5Lmg6LWE5paZ5YWN6LS56aKG5Y+W6K+35Yqg5omj5omj5Y+35pivMTAxODkyNTc4MA==

### 回答1: Spring Boot集成FastDFS可以通过以下步骤实现: 1. 添加FastDFS依赖 在pom.xml文件中添加以下依赖: ```xml <dependency> <groupId>com.github.tobato</groupId> <artifactId>fastdfs-client</artifactId> <version>1.27.2</version> </dependency> ``` 2. 配置FastDFS连接信息 在application.properties文件中添加以下配置: ```properties # FastDFS配置 fdfs.tracker-list=192.168.1.100:22122,192.168.1.101:22122 fdfs.connect-timeout=500 fdfs.so-timeout=30000 fdfs.read-timeout=60000 ``` 其中,fdfs.tracker-list为FastDFS Tracker服务器列表,可以配置多个,用逗号分隔;fdfs.connect-timeout、fdfs.so-timeout、fdfs.read-timeout分别为连接、读取、写入超时时间。 3. 编写FastDFS文件上传代码 可以通过以下代码实现文件上传: ```java @Service public class FastDFSFileService { @Autowired private FastFileStorageClient fastFileStorageClient; public String uploadFile(MultipartFile file) throws IOException { StorePath storePath = fastFileStorageClient.uploadFile(file.getInputStream(), file.getSize(), FilenameUtils.getExtension(file.getOriginalFilename()), null); return storePath.getFullPath(); } } ``` 其中,FastFileStorageClient是FastDFS提供的文件存储客户端,可以通过@Autowired注入使用;uploadFile方法用于上传文件,返回文件在FastDFS中的路径。 4. 编写FastDFS文件下载代码 可以通过以下代码实现文件下载: ```java @Service public class FastDFSFileService { @Autowired private DownloadByteArray callback; @Autowired private FastFileStorageClient fastFileStorageClient; public byte[] downloadFile(String filePath) { return fastFileStorageClient.downloadFile(filePath, callback); } } ``` 其中,DownloadByteArray是FastDFS提供的文件下载回调接口,可以通过@Autowired注入使用;downloadFile方法用于下载文件,返回文件的字节数组。 以上就是Spring Boot集成FastDFS的基本步骤,可以根据实际需求进行扩展和优化。 ### 回答2: FastDFS是一个开源的分布式文件系统,采用了多台服务器集群来存储文件,并具有高可靠性、高扩展性和高性能的优点。而SpringBoot是一个快速构建企业级应用的开发框架,可以帮助开发者更加便捷地集成第三方库和框架。 在SpringBoot集成FastDFS,需要按照以下步骤进行操作: 1. 添加FastDFS的依赖 在pom.xml文件中,添加FastDFS的依赖: ```xml <dependency> <groupId>com.github.tobato</groupId> <artifactId>fastdfs-client</artifactId> <version>1.27.1</version> </dependency> ``` 2. 配置FastDFS的连接信息 在application.properties(或application.yml)文件中,配置FastDFS的连接信息,如下: ```properties fdfs.tracker-list=192.168.1.100:22122,192.168.1.101:22122 ``` 3. 创建FastDFS的存储客户端 创建FastDFS的存储客户端,代码如下: ```java @Configuration public class FdfsClientConfig { @Bean public DefaultFastFileStorageClient storageClient() { TrackerClient trackerClient = new TrackerClient(); TrackerServer trackerServer = trackerClient.getTrackerServer(); StorageServer storageServer = new StorageServer(trackerServer,null); return new DefaultFastFileStorageClient(trackerServer, storageServer); } } ``` 4. 使用FastDFS存储文件 在使用过程中,调用FastDFS的存储客户端,使用FastDFS存储文件。例如: ```java @Autowired private DefaultFastFileStorageClient storageClient; public String uploadFile(MultipartFile file) throws IOException { StorePath storePath = storageClient.uploadFile(file.getInputStream(), file.getSize(), FilenameUtils.getExtension(file.getOriginalFilename()), null); return storePath.getFullPath(); } ``` 在以上代码中,首先注入FastDFS的存储客户端,然后调用其uploadFile方法,将文件存储到FastDFS中,并返回文件的路径。 通过以上四步,就可以在SpringBoot中成功集成FastDFS,并使用FastDFS来存储文件,以达到分布式存储和高可靠性的目的。 ### 回答3: SpringBoot是一个快速开发框架,能够快速开发各种类型的Java应用程序。FastDFS是一个轻量级的分布式文件系统,用于存储大文件。本文将介绍如何使用SpringBoot集成FastDFS。 一、搭建FastDFS环境 1. 安装libfastcommon $ tar zxvf libfastcommon-1.0.7.tar.gz $ cd libfastcommon-1.0.7 $ ./make.sh $ sudo ./make.sh install 2. 安装FastDFS $ tar zxvf FastDFS_v5.11.tar.gz $ cd FastDFS $ ./make.sh $ sudo ./make.sh install 3. 配置Tracker服务器 在/etc/fdfs目录下创建tracker.conf文件,内容如下: port=22122 base_path=/var/fdfs/tracker log_level=info run_by_group=fastdfs run_by_user=fastdfs 4. 配置Storage服务器 在/etc/fdfs目录下创建storage.conf,内容如下: # mount point /mnt/hdd1 /mnt/hdd2 #Base path for file storage base_path=/var/fdfs/storage #Store path for file storge store_path0=/mnt/hdd1 store_path1=/mnt/hdd2 #Storage tracker server tracker_server=192.168.1.1:22122 5. 启动FastDFS服务 在不同的服务器上分别启动Tracker和Storage服务。 $ sudo /etc/init.d/fdfs_trackerd start $ sudo /etc/init.d/fdfs_storaged start 检查服务是否已启动: $ ps aux | grep fdfs 二、SpringBoot集成FastDFS 1. 添加maven依赖 <dependency> <groupId>com.github.tobato</groupId> <artifactId>fastdfs-client</artifactId> <version>1.25.2</version> </dependency> 2. 配置文件 spring: #fastdfs配置 tracker-list: 192.168.1.1:22122 3. 编写代码 使用FastDFS需要创建TrackerClient和StorageClient两个对象。 通过TrackerClient对象可以得到Storage服务器地址。 通过StorageClient对象上传文件和下载文件。 上传: StorePath storePath = storageClient.uploadFile(file.getInputStream(), file.getSize(), fileExtName, null); String fullPath = storePath.getFullPath(); 下载: byte[] bytes = storageClient.downloadFile(group, path); return ResponseEntity.ok().contentType(MediaType.IMAGE_JPEG).contentLength(bytes.length).body(bytes); 通过以上步骤,即可快速集成FastDFSSpringBoot中。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值