Spring Boot 集成 MinIO 与 KKFile 实现文件预览功能

简介: 本文详细介绍如何在Spring Boot项目中集成MinIO对象存储系统与KKFileView文件预览工具,实现文件上传及在线预览功能。首先搭建MinIO服务器,并在Spring Boot中配置MinIO SDK进行文件管理;接着通过KKFileView提供文件预览服务,最终实现文档管理系统的高效文件处理能力。

在现代的 Web 应用中,文件预览功能是提升用户体验的重要部分,尤其是在文档管理系统中。本文将带你逐步实现如何在 Spring Boot 项目中集成 MinIO(一个对象存储系统)与 KKFileView(一个开源文件预览工具),以实现对各种类型文件的在线预览。

项目准备

在开始之前,请确保你已经安装和配置好了以下工具:

  • Java 11+
  • Spring Boot
  • MinIO 服务器
  • KKFileView

第一步:搭建 MinIO 服务器

首先,我们需要配置 MinIO 作为对象存储服务器。你可以在本地或服务器上运行 MinIO。

  1. 下载 MinIO
    MinIO 官方网站 下载适用于你操作系统的版本。
  2. 运行 MinIO 服务器在安装完 MinIO 后,可以使用以下命令启动 MinIO:

minio server /data --console-address ":9001"
  1. /data 是存储文件的路径,9001 是 MinIO 控制台的端口。
  2. 访问 MinIO 控制台通过浏览器访问 http://localhost:9001,并使用默认的 access key 和 secret key 登录。你可以在 MinIO 控制台中创建一个 bucket 用来存储文件。

第二步:集成 Spring Boot 与 MinIO

在 Spring Boot 项目中,我们将使用 MinIO SDK 来上传和下载文件。

1. 添加依赖在 pom.xml 中添加 MinIO SDK 的依赖:

<dependency>    
  <groupId>io.minio</groupId>    
  <artifactId>minio</artifactId>    
  <version>8.0.3</version>
</dependency>

2. 配置 MinIO在 application.properties 中添加 MinIO 的配置信息:

 minio.endpoint=http://localhost:9000
 minio.accessKey=minioadmin
 minio.secretKey=minioadmin
 minio.bucketName=files

3. 创建 MinIO Service编写一个 MinIOService 类,用于文件的上传和下载:

@Service
public class MinioService {
    @Value("${minio.endpoint}")    
    private String minioEndpoint;    
    @Value("${minio.accessKey}")    
    private String minioAccessKey;    
    @Value("${minio.secretKey}")    
    private String minioSecretKey;    
    @Value("${minio.bucketName}")    
    private String bucketName;
    
    private MinioClient minioClient;
    @PostConstruct
    public void init() {        
    minioClient = MinioClient.builder()            
        .endpoint(minioEndpoint)            
        .credentials(minioAccessKey, minioSecretKey)            
        .build();    
    }
    public String uploadFile(MultipartFile file) throws Exception {
         String fileName = System.currentTimeMillis() + "-" + file.getOriginalFilename();
         minioClient.putObject(
            PutObjectArgs.builder()
            .bucket(bucketName)
            .object(fileName)
            .stream(file.getInputStream(), file.getSize(), -1)
            .contentType(file.getContentType())
            .build()
    );
    return fileName;
}
public String getFileUrl(String fileName) {
        return minioClient.getPresignedObjectUrl(
        GetPresignedObjectUrlArgs.builder()
        .bucket(bucketName)
        .object(fileName)
        .build()
        );
    }
}

第三步:集成 KKFileView 实现文件预览

KKFileView 支持多种格式的文件预览,例如 PDF、Word、Excel 等。

  1. 下载并运行 KKFileViewKKFileView 官方仓库 下载源码或使用 Docker 安装:
docker run -d -p 8012:8012 --name kkfileview keking/kkfileview

2. 配置 KKFileView 服务KKFileView 提供了一个 REST API,用于文件预览。我们可以将文件的 URL 传递给 KKFileView,实现在线预览。

在 application.properties 中配置 KKFileView 服务的地址:

kkfileview.server=http://localhost:8012

3. 实现预览接口在 MinioService 中创建一个方法,用于生成文件的预览 URL:

public String getPreviewUrl(String fileName) {
    String fileUrl = getFileUrl(fileName);
    return kkFileViewServer + "/onlinePreview?url=" + URLEncoder.encode(fileUrl, StandardCharsets.UTF_8);
}

4.Controller 实现文件上传和预览创建一个 FileController,实现文件上传和预览的接口:

@RestController
@RequestMapping("/files")
public class FileController {
    @Autowired
    private MinioService minioService;
    @PostMapping("/upload")
    public ResponseEntity<String> uploadFile(@RequestParam("file") MultipartFile file) {
        try {
            String fileName = minioService.uploadFile(file);
            return ResponseEntity.ok(fileName);
        } catch (Exception e) {
            return ResponseEntity.status(HttpStatus.INTERNAL_SERVER_ERROR).body(e.getMessage());
        }
    }
    @GetMapping("/preview/{fileName}")
    public ResponseEntity<String> previewFile(@PathVariable String fileName) {
        String previewUrl = minioService.getPreviewUrl(fileName);
        return ResponseEntity.ok(previewUrl);
    }
}


第四步:测试文件上传与预览

  1. 文件上传
    使用 Postman 或前端页面上传文件,访问 /files/upload 接口。
  2. 文件预览
    访问 /files/preview/{fileName},即可获取文件的预览链接,打开后即可在浏览器中预览文件。

总结

通过本文的介绍,你已经成功地集成了 MinIO 作为文件存储系统,并结合 KKFileView 实现了文件的在线预览功能。这种组合非常适合文档管理系统和需要处理大量文件的企业级应用。你可以根据需要对 MinIO 和 KKFileView 进行进一步的优化和扩展。

相关文章
|
16天前
|
消息中间件 缓存 Java
手写模拟Spring Boot启动过程功能
【11月更文挑战第19天】Spring Boot自推出以来,因其简化了Spring应用的初始搭建和开发过程,迅速成为Java企业级应用开发的首选框架之一。本文将深入探讨Spring Boot的背景历史、业务场景、功能点以及底层原理,并通过Java代码手写模拟Spring Boot的启动过程,帮助读者深入理解其工作机制。
31 3
|
16天前
|
Java 开发者 微服务
手写模拟Spring Boot自动配置功能
【11月更文挑战第19天】随着微服务架构的兴起,Spring Boot作为一种快速开发框架,因其简化了Spring应用的初始搭建和开发过程,受到了广大开发者的青睐。自动配置作为Spring Boot的核心特性之一,大大减少了手动配置的工作量,提高了开发效率。
36 0
|
2月前
|
Java API 数据库
构建RESTful API已经成为现代Web开发的标准做法之一。Spring Boot框架因其简洁的配置、快速的启动特性及丰富的功能集而备受开发者青睐。
【10月更文挑战第11天】本文介绍如何使用Spring Boot构建在线图书管理系统的RESTful API。通过创建Spring Boot项目,定义`Book`实体类、`BookRepository`接口和`BookService`服务类,最后实现`BookController`控制器来处理HTTP请求,展示了从基础环境搭建到API测试的完整过程。
48 4
|
2月前
|
JavaScript 安全 Java
如何使用 Spring Boot 和 Ant Design Pro Vue 实现动态路由和菜单功能,快速搭建前后端分离的应用框架
本文介绍了如何使用 Spring Boot 和 Ant Design Pro Vue 实现动态路由和菜单功能,快速搭建前后端分离的应用框架。首先,确保开发环境已安装必要的工具,然后创建并配置 Spring Boot 项目,包括添加依赖和配置 Spring Security。接着,创建后端 API 和前端项目,配置动态路由和菜单。最后,运行项目并分享实践心得,包括版本兼容性、安全性、性能调优等方面。
162 1
|
2月前
|
Java API 数据库
Spring Boot框架因其简洁的配置、快速的启动特性及丰富的功能集而备受开发者青睐
本文通过在线图书管理系统案例,详细介绍如何使用Spring Boot构建RESTful API。从项目基础环境搭建、实体类与数据访问层定义,到业务逻辑实现和控制器编写,逐步展示了Spring Boot的简洁配置和强大功能。最后,通过Postman测试API,并介绍了如何添加安全性和异常处理,确保API的稳定性和安全性。
38 0
|
29天前
|
JavaScript 安全 Java
如何使用 Spring Boot 和 Ant Design Pro Vue 构建一个具有动态路由和菜单功能的前后端分离应用。
本文介绍了如何使用 Spring Boot 和 Ant Design Pro Vue 构建一个具有动态路由和菜单功能的前后端分离应用。首先,创建并配置 Spring Boot 项目,实现后端 API;然后,使用 Ant Design Pro Vue 创建前端项目,配置动态路由和菜单。通过具体案例,展示了如何快速搭建高效、易维护的项目框架。
102 62
|
3天前
|
消息中间件 Java Kafka
什么是Apache Kafka?如何将其与Spring Boot集成?
什么是Apache Kafka?如何将其与Spring Boot集成?
27 5
|
2月前
|
XML Java Kotlin
springboot + minio + kkfile实现文件预览
本文介绍了如何在容器中安装和启动kkfileviewer,并通过Spring Boot集成MinIO实现文件上传与预览功能。首先,通过下载kkfileviewer源码并构建Docker镜像来部署文件预览服务。接着,在Spring Boot项目中添加MinIO依赖,配置MinIO客户端,并实现文件上传与获取预览链接的接口。最后,通过测试验证文件上传和预览功能的正确性。
springboot + minio + kkfile实现文件预览
|
27天前
|
JavaScript 安全 Java
如何使用 Spring Boot 和 Ant Design Pro Vue 构建一个前后端分离的应用框架,实现动态路由和菜单功能
本文介绍了如何使用 Spring Boot 和 Ant Design Pro Vue 构建一个前后端分离的应用框架,实现动态路由和菜单功能。首先,确保开发环境已安装必要的工具,然后创建并配置 Spring Boot 项目,包括添加依赖和配置 Spring Security。接着,创建后端 API 和前端项目,配置动态路由和菜单。最后,运行项目并分享实践心得,帮助开发者提高开发效率和应用的可维护性。
51 2
|
1月前
|
JSON Java API
springboot集成ElasticSearch使用completion实现补全功能
springboot集成ElasticSearch使用completion实现补全功能
35 1