MinIO Go 客户端 API

MinIO 是一个基于 Apache License v2.0 开源协议的对象存储服务,与 Amazon S3 云存储服务兼容,适合于存储大容量非结构化的数据,例如图片、视频、日志文件、备份数据和容器 / 虚拟机镜像等。在 Go 语言中,可以使用 MinIO 官方提供的 Go 客户端库与 MinIO 服务进行交互。以下是关于在 Go 语言中使用 MinIO 的详细代码如下介绍:

Go 复制代码
package minio

import (
	"bytes"
	"context"
	"fmt"
	"github.com/minio/minio-go/v7"
	"github.com/minio/minio-go/v7/pkg/credentials"
	"io"
	"log"
	"net/url"
	"os"
	"path"
	"time"
)

type Minio struct {
	client     *minio.Client // 连接对象
	bucketName string // 桶名称
}

// NewMinio ...
// endpoint 连接地址;accessKey 访问key;secret 访问密钥;bucketName 桶名称
func NewMinio(endpoint, accessKey, secret, bucketName string) Minio {
	// Initialize minio client object.
	minioClient, err := minio.New(endpoint, &minio.Options{
		Creds:  credentials.NewStaticV4(accessKey, secret, ""),
		Secure: false,
	})
	if err != nil {
		log.Fatal("文件服务连接失败;err=", err)
	}
	return Minio{
		client: minioClient,
		//logger:     logger,
		bucketName: bucketName,
	}
}

// CreateBucket 创建桶
func (m Minio) CreateBucket(ctx context.Context) error {
	err := m.client.MakeBucket(ctx, m.bucketName, minio.MakeBucketOptions{Region: "cn-north-1"})
	if err != nil {
		// 检查存储桶是否已存在,若已存在导致的错误则忽略
		if exists, errExists := m.BucketExists(ctx, m.bucketName); errExists == nil && exists {
			return nil
		}
		return fmt.Errorf("创建存储桶失败: %v", err)
	}
	//m.logger.Info("存储桶 %s 创建成功\n", m.bucketName)
	return nil
}

// ListBuckets 查询桶列表
func (m Minio) ListBuckets(ctx context.Context) ([]minio.BucketInfo, error) {
	buckets, err := m.client.ListBuckets(ctx)
	if err != nil {
		return nil, err
	}
	return buckets, nil
}

// BucketExists 检查桶是否存在
func (m Minio) BucketExists(ctx context.Context, bucketName string) (bool, error) {
	found, err := m.client.BucketExists(ctx, bucketName)
	if err != nil {
		fmt.Println(err)
		return false, err
	}
	return found, nil
}

// RemoveBucket 删除桶
func (m Minio) RemoveBucket(ctx context.Context) error {
	isExist, err := m.BucketExists(ctx, m.bucketName)
	if err != nil {
		fmt.Printf("Check %s err:%s", m.bucketName, err.Error())
		return err
	}
	if isExist {
		fmt.Printf("%s exists! Start delete....\n", m.bucketName)
		// 删除
		if err = m.client.RemoveBucket(ctx, m.bucketName); err != nil {
			fmt.Printf("Fail to remove %s:%s\n", m.bucketName, err.Error())
			return err
		}
		fmt.Printf("Success to remove %s\n", m.bucketName)
	} else {
		fmt.Printf("%s not exists!\n", m.bucketName)
	}
	return nil
}

// UploadObject 上传文件对象
func (m Minio) UploadObject(ctx context.Context, objectName string, file *os.File) (*minio.UploadInfo, error) {
	fileStat, err := file.Stat()
	if err != nil {
		return nil, err
	}
	fileType := "application/octet-stream"
	switch path.Ext(objectName) {
	case ".jpg", ".jpeg":
		fileType = "image/jpeg"
	case ".png":
		fileType = "image/png"
	case ".gif":
		fileType = "image/gif"
	case ".webp":
		fileType = "image/webp"
	case ".mp4":
		fileType = "video/mp4"
	case ".avi":
		fileType = "video/avi"
	case ".pdf":
		fileType = "application/pdf"
	case ".doc":
		fileType = "application/msword"
	}
	// upload the file
	uploadInfo, err := m.client.PutObject(
		ctx,
		m.bucketName,
		objectName,
		file,
		fileStat.Size(),
		minio.PutObjectOptions{ContentType: fileType})
	return &uploadInfo, err
}

// ReadObject 获取文件对象
func (m Minio) ReadObject(ctx context.Context, objectName string) ([]byte, error) {
	contentBuffer, err := m.client.GetObject(ctx, m.bucketName, objectName, minio.GetObjectOptions{})
	if err != nil {
		return nil, err
	}
	// read the content from the buffer
	contentBytes := new(bytes.Buffer)
	if _, err = io.Copy(contentBytes, contentBuffer); err != nil {
		return nil, err
	}
	return contentBytes.Bytes(), nil
}

// StateObjects 查询文件信息
func (m Minio) StateObjects(ctx context.Context, objectName string) (*minio.ObjectInfo, error) {
	objInfo, err := m.client.StatObject(ctx, m.bucketName, objectName, minio.StatObjectOptions{})
	if err != nil {
		return nil, err
	}
	return &objInfo, err
}

// PresignedGetObject 创建预览地址
func (m Minio) PresignedGetObject(ctx context.Context, objectName string) (*url.URL, error) {
	reqParams := make(url.Values)
	// 若需要生成的链接直接下载文件的把下面的注释打开,需要预览的则不需要打开
	//reqParams.Set("response-content-disposition", "attachment; filename="+path.Base(objectName))
	// Generates a presigned url which expires in a day.
	presignedURL, err := m.client.PresignedGetObject(ctx, m.bucketName, objectName, time.Second*24*60*60, reqParams)
	if err != nil {
		return nil, err
	}
	return presignedURL, err
}

// RemoveObject 删除文件对象
func (m Minio) RemoveObject(ctx context.Context, objectName string) error {
	opts := minio.RemoveObjectOptions{}
	err := m.client.RemoveObject(ctx, m.bucketName, objectName, opts)
	if err != nil {
		fmt.Println(err)
		return err
	}
	return nil
}

官网API地址MinIO Go Client API Reference --- MinIO中文文档 | MinIO Linux中文文档

相关推荐
zopple16 分钟前
常见的 Spring 项目目录结构
java·后端·spring
是娇娇公主~1 小时前
C++ 中 std::deque 的原理?它内部是如何实现的?
开发语言·c++·stl
SuperEugene1 小时前
Axios 接口请求规范实战:请求参数 / 响应处理 / 异常兜底,避坑中后台 API 调用混乱|API 与异步请求规范篇
开发语言·前端·javascript·vue.js·前端框架·axios
lars_lhuan2 小时前
Go WaitGroup 源码解析
golang
xuxie992 小时前
N11 ARM-irq
java·开发语言
cjy0001112 小时前
springboot的 nacos 配置获取不到导致启动失败及日志不输出问题
java·spring boot·后端
wefly20173 小时前
从使用到原理,深度解析m3u8live.cn—— 基于 HLS.js 的 M3U8 在线播放器实现
java·开发语言·前端·javascript·ecmascript·php·m3u8
小江的记录本3 小时前
【事务】Spring Framework核心——事务管理:ACID特性、隔离级别、传播行为、@Transactional底层原理、失效场景
java·数据库·分布式·后端·sql·spring·面试
sheji34163 小时前
【开题答辩全过程】以 基于springboot的校园失物招领系统为例,包含答辩的问题和答案
java·spring boot·后端
luanma1509803 小时前
PHP vs C++:编程语言终极对决
开发语言·c++·php