Nextjs14 + minio实现文件上传下载

本文介绍了如何在Next.js14项目中集成Docker部署的Minio服务,包括安装Minio客户端、安全存储秘钥、处理文件上传和下载操作,以及处理文件类型和错误处理。
摘要由CSDN通过智能技术生成

Nextjs14 + Minio实现文件的上传下载

事先准备

  • 初始化nextjs项目

  • 搭建minio服务 (docker一分钟搞定 下面是链接)

https://nextjs.org/docs/getting-started/installation

Docker 搭建 Minio 容器 (完整详细版)_docker minio-CSDN博客

第一步

下载minio客户端

yarn add minio
或者
npm i minio

第二步

随便找个顺眼的文件夹 我是放在lib文件夹下面 起名 file-uploader 供后面接口编写引入

切记秘钥啥的放 .env文件里用以下方式导入 .gitignore 文件里也别忘了配置,别把 .env文件

也提交上去了 还有该文件不要在 "use client"也就是客户端渲染的文件里面引入(那样一样会暴露你的敏感信息)

本人因为不小心提交阿里巴巴oss秘钥到github导致泄露 所以对于敏感信息比较谨慎

const Minio = require('minio');

export const minioClient = new Minio.Client({
    endPoint: process.env.NEXT_PUBLIC_MINIO_END_POINT,
    port: parseInt(process.env.NEXT_PUBLIC_MINIO_PORT!),
    useSSL: process.env.NEXT_PUBLIC_MINIO_USE_SSL === 'true',
    accessKey: process.env.NEXT_PUBLIC_MINIO_ACCESS_KEY,
    secretKey: process.env.NEXT_PUBLIC_MINIO_SECRET_KEY,
});

[!NOTE]

这里有个小坑

如果我使用 ES6 的模块导入语法的话

像这样 import Minio from “minio”

就报错说 Minio is undefined

知道为什么的兄弟评论下方告诉我一下 谢谢

第三步

下载下mime(获取文件后缀名)

yarn add mime

编写上传文件接口 (写到/app/api/)路径下即可 名字随意

import mime from 'mime';
import { minioClient } from '@/lib/file-uploader';

export async function POST(req: Request) {
    const formData = await req.formData();
    const file = formData.get('file') as Blob | null;
    if (!file) {
        return NextResponse.json({ error: 'field file not empty' }, { status:                               400 });
    }
    const buffer = Buffer.from(await file.arrayBuffer());
    try {
        // 如果想要在指定文件夹下储存该图片  直接加上前缀即可 我这里加了个/image
        const url = `/image/${自定义文件名}.${mime.getExtension(file.type)}`;
        await minioClient.putObject('blog-dashboard', url, buffer);
        return NextResponse.json({ url });
    } catch (error) {
        console.log('UPLOAD_POST', error);
        return new NextResponse('Internal Error', { status: 500 });
    }
}

最后编写下载接口

import { minioClient } from '@/lib/file-uploader';
import { NextResponse } from 'next/server';

export async function GET(req: Request, { params }: { params: { fileName: string } }) {
    const blob = await minioClient.getObject('blog-dashboard', `/image/${params.fileName}`);
    const headers = new Headers();
    // headers.set('Content-Type', 'image/*'); 默认动作是下载
    headers.set('content-Type', 'text/plain'); // 默认动作是浏览器展示

    return new NextResponse(blob, { status: 200, statusText: 'OK', headers });
}

  • 4
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
实现Spring Boot与Minio的大文件上传并解压的功能,可以按照以下步骤进行操作: 1. 首先,在Spring Boot项目的pom.xml文件中引入Minio的依赖。可以使用以下代码将Minio的依赖添加到项目中: ``` <dependency> <groupId>io.minio</groupId> <artifactId>minio</artifactId> <version>8.2.1</version> </dependency> ``` 2. 然后,将大文件分片并上传到Minio对象存储服务。可以按照以下步骤进行操作: - 将要上传的大文件进行分片处理,可以使用文件分片算法将大文件分成多个小块。 - 将分片后的文件依次上传到Minio对象存储服务,并指定一个临时文件名。 3. 分片上传完成后,将所有分片合并为一个完整的文件。可以按照以下步骤进行操作: - 从Minio中读取所有分片文件的流。 - 将分片流写入到一个临时文件中,以便后续解压。 4. 解压临时文件。可以按照以下步骤进行操作: - 使用合适的解压库或工具,对临时文件进行解压。 - 解压后的文件可以按需求进行进一步处理,例如再次上传到Minio或其他存储系统。 综上所述,要实现Spring Boot与Minio的大文件上传并解压功能,需要将文件分片并上传到Minio,然后将分片合并为完整文件,最后解压文件。这样可以实现大文件的上传和解压操作。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [Spring boot + minio 分片上传](https://blog.csdn.net/XIAOTONGZHU/article/details/130346735)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [SpringBoot 使用 Minio 进行文件存储](https://blog.csdn.net/qq_43692950/article/details/125961685)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [Windows常用软件压缩包,后端Java适用于springboot 2.6.x等高版本](https://download.csdn.net/download/m0_55710969/85062866)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值