Bitzsoft.Integrations.FileStorage.Minio
1.0.0-alpha.7
This is a prerelease version of Bitzsoft.Integrations.FileStorage.Minio.
dotnet add package Bitzsoft.Integrations.FileStorage.Minio --version 1.0.0-alpha.7
NuGet\Install-Package Bitzsoft.Integrations.FileStorage.Minio -Version 1.0.0-alpha.7
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Bitzsoft.Integrations.FileStorage.Minio" Version="1.0.0-alpha.7" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="Bitzsoft.Integrations.FileStorage.Minio" Version="1.0.0-alpha.7" />
<PackageReference Include="Bitzsoft.Integrations.FileStorage.Minio" />
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add Bitzsoft.Integrations.FileStorage.Minio --version 1.0.0-alpha.7
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#r "nuget: Bitzsoft.Integrations.FileStorage.Minio, 1.0.0-alpha.7"
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
#:package Bitzsoft.Integrations.FileStorage.Minio@1.0.0-alpha.7
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=Bitzsoft.Integrations.FileStorage.Minio&version=1.0.0-alpha.7&prerelease
#tool nuget:?package=Bitzsoft.Integrations.FileStorage.Minio&version=1.0.0-alpha.7&prerelease
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
Bitzsoft.Integrations.FileStorage.Minio
MinIO 文件存储实现。
功能特性
- 完整实现
IFileStore接口:覆盖所有文件与存储桶操作 - 扩展接口
IMinioFileStore:MinIO 文件存储服务标识接口,支持未来扩展 - 预签名 URL:生成带过期时间的下载地址和上传地址
- 存储桶管理:创建、删除、判断存储桶是否存在
- 文件元数据:保存文件时支持设置 ContentType
- 配置提供器模式:通过
IMinioConfigProvider抽象配置获取,支持静态配置或动态配置中心 - IHttpClientFactory 集成:通过
Microsoft.Extensions.Http管理 HTTP 连接
安装
.NET CLI
dotnet add package Bitzsoft.Integrations.FileStorage.Minio
PackageReference
<PackageReference Include="Bitzsoft.Integrations.FileStorage.Minio" Version="1.0.0" />
配置
appsettings.json
{
"Minio": {
"Endpoint": "minio.example.com",
"AccessKey": "your-access-key",
"SecretKey": "your-secret-key",
"UseSSL": false,
"DefaultBucketName": "my-app-bucket",
"HttpClientName": "FileStorage",
"UploadUrlExpiration": 3600,
"DownloadUrlExpiration": 43200
}
}
| 配置项 | 说明 | 默认值 |
|---|---|---|
Endpoint |
MinIO 服务地址,不含协议前缀 | -- |
AccessKey |
访问密钥(AccessKey) | -- |
SecretKey |
密钥(SecretKey) | -- |
UseSSL |
是否使用 HTTPS | false |
DefaultBucketName |
默认存储桶名称,Args 中未指定 BucketName 时使用 | -- |
HttpClientName |
HttpClient 名称,用于 IHttpClientFactory 创建客户端 |
-- |
UploadUrlExpiration |
上传预签名地址过期时间(秒) | 3600 |
DownloadUrlExpiration |
下载预签名地址过期时间(秒) | 43200 |
注册服务
使用 DI 扩展方法(推荐)
using Bitzsoft.Integrations.FileStorage.Minio;
using Microsoft.Extensions.DependencyInjection;
var services = new ServiceCollection();
// 注册 HttpClient 工厂
services.AddHttpClient("FileStorage");
// 一行注册 MinIO 文件存储服务
services.AddBitzsoftMinioFileStorage(options =>
{
options.Endpoint = "minio.example.com";
options.AccessKey = "your-access-key";
options.SecretKey = "your-secret-key";
options.DefaultBucketName = "my-app-bucket";
options.UseSSL = false;
});
从 IConfiguration 绑定配置
using Bitzsoft.Integrations.FileStorage;
using Bitzsoft.Integrations.FileStorage.Minio;
using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.DependencyInjection;
var configuration = new ConfigurationBuilder()
.AddJsonFile("appsettings.json")
.Build();
var services = new ServiceCollection();
// 注册 HttpClient 工厂(MinioFileStore 通过 IHttpClientFactory 创建 HTTP 客户端)
services.AddHttpClient("FileStorage");
// 注册处理器工厂
services.AddSingleton<IFileNameProcessorFactory, DefaultFileNameProcessorFactory>();
services.AddSingleton<IBucketNameProcessorFactory, DefaultBucketNameProcessorFactory>();
// 从配置节绑定 MinioOptions
services.AddSingleton<IMinioConfigProvider>(sp =>
{
var options = configuration.GetSection("Minio").Get<MinioOptions>();
return new MinioConfigProvider(options);
});
services.AddSingleton<IMinioFileStore, MinioFileStore>();
services.AddSingleton<IFileStore>(sp => sp.GetRequiredService<IMinioFileStore>());
使用 IOptions 模式
using Bitzsoft.Integrations.FileStorage;
using Bitzsoft.Integrations.FileStorage.Minio;
using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.DependencyInjection;
var services = new ServiceCollection();
services.AddHttpClient("FileStorage");
services.AddSingleton<IFileNameProcessorFactory, DefaultFileNameProcessorFactory>();
services.AddSingleton<IBucketNameProcessorFactory, DefaultBucketNameProcessorFactory>();
// 配置选项
services.Configure<MinioOptions>(
configuration.GetSection("Minio"));
// MinioConfigProvider 内部通过 IOptions<MinioOptions> 获取配置
services.AddSingleton<IMinioConfigProvider, MinioConfigProvider>();
services.AddSingleton<IMinioFileStore, MinioFileStore>();
services.AddSingleton<IFileStore>(sp => sp.GetRequiredService<IMinioFileStore>());
使用示例
保存文件并获取下载链接
using Bitzsoft.Integrations.FileStorage;
using Bitzsoft.Integrations.FileStorage.Minio;
public class ReportService
{
private readonly IMinioFileStore _fileStore;
public ReportService(IMinioFileStore fileStore)
{
_fileStore = fileStore;
}
public async Task<string> UploadReportAsync(Stream pdfStream, string reportName)
{
// 保存 PDF 到默认存储桶
var result = await _fileStore.SaveFileAsync(
pdfStream, $"{reportName}.pdf");
// 生成 12 小时有效的下载链接
var downloadUrl = await _fileStore.GenerateDownloadUrlAsync(
result.FilePath);
return downloadUrl;
}
}
通过 IFileStore 抽象使用
using Bitzsoft.Integrations.FileStorage;
public class ContractService
{
private readonly IFileStore _fileStore;
public ContractService(IFileStore fileStore)
{
_fileStore = fileStore;
}
public async Task<FileResult> UploadContractAsync(
Stream contractStream, string contractId)
{
var args = new SaveFileArgs($"{contractId}.pdf", contractStream)
{
ContentType = "application/pdf"
};
return await _fileStore.SaveFileAsync(args);
}
}
从远程 URL 拉取文件到 MinIO
using Bitzsoft.Integrations.FileStorage;
using Bitzsoft.Integrations.FileStorage.Minio;
public class MediaSyncService
{
private readonly IFileStore _fileStore;
public MediaSyncService(IFileStore fileStore)
{
_fileStore = fileStore;
}
public async Task<FileResult> SyncExternalImageAsync(string imageUrl, string saveAs)
{
var args = new SaveFileByUrlArgs(saveAs, imageUrl)
{
BucketName = "media-assets"
};
return await _fileStore.SaveFileByUrlAsync(args);
}
}
复制与移动文件
using Bitzsoft.Integrations.FileStorage;
using Bitzsoft.Integrations.FileStorage.Minio;
public class FileOrganizer
{
private readonly IFileStore _fileStore;
public FileOrganizer(IFileStore fileStore)
{
_fileStore = fileStore;
}
public async Task ArchiveFileAsync(string sourceFile, string archivePath)
{
// 复制文件到归档路径
await _fileStore.CopyFileAsync(sourceFile, archivePath);
// 删除原文件(等同于 MoveFileAsync)
await _fileStore.DeleteFileAsync(sourceFile);
}
public async Task MoveToBucketAsync(
string fileName, string sourceBucket, string destBucket)
{
var sourceArgs = new FileStorageArgs(fileName) { BucketName = sourceBucket };
var destArgs = new FileStorageArgs(fileName) { BucketName = destBucket };
await _fileStore.MoveFileAsync(sourceArgs, destArgs);
}
}
核心类型一览
| 类型 | 说明 |
|---|---|
IMinioFileStore |
MinIO 文件存储接口,继承 IFileStore |
MinioFileStore |
默认实现类 |
MinioOptions |
MinIO 连接配置 |
IMinioConfigProvider |
配置提供器接口 |
MinioConfigProvider |
默认配置提供器(支持 IOptions<MinioOptions>) |
ServiceCollectionExtensions |
DI 扩展方法 AddBitzsoftMinioFileStorage |
依赖
Bitzsoft.Integrations.Compatibility,基础工具库- Bitzsoft.Integrations.FileStorage,多云文件存储抽象层
Minio,MinIO 官方 SDKMicrosoft.Extensions.Http,HttpClient 工厂支持
相关包
- Bitzsoft.Integrations.FileStorage,多云文件存储抽象层
- Bitzsoft.Integrations.FileStorage.Aliyun,阿里云 OSS 文件存储实现
- Bitzsoft.Integrations.FileStorage.Azure,Azure Blob Storage 文件存储实现
- Bitzsoft.Integrations.FileStorage.Aws,AWS S3 文件存储实现
- Bitzsoft.Integrations.FileStorage.Tencent,腾讯云 COS 文件存储实现
- Bitzsoft.Integrations.FileStorage.Huawei,华为云 OBS 文件存储实现
- Bitzsoft.Integrations.FileStorage.Kingsoft,金山云 KS3 文件存储实现
- Bitzsoft.Integrations.FileStorage.Qiniu,七牛云 Kodo 文件存储实现
- Bitzsoft.Integrations.FileStorage.Upyun,又拍云文件存储实现
- Bitzsoft.Integrations.FileStorage.Nas,NAS / 本地文件系统存储实现
- Bitzsoft.Integrations.FileStorage.All,全部云存储实现聚合包
| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET | net5.0 is compatible. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 is compatible. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. net10.0 is compatible. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.0-windows was computed. |
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
-
net10.0
- Bitzsoft.Integrations.Compatibility (>= 1.0.0-alpha.7)
- Bitzsoft.Integrations.FileStorage (>= 1.0.0-alpha.7)
- Microsoft.Extensions.Http (>= 10.0.9)
- Minio (>= 7.0.0)
-
net5.0
- Bitzsoft.Integrations.Compatibility (>= 1.0.0-alpha.7)
- Bitzsoft.Integrations.FileStorage (>= 1.0.0-alpha.7)
- Microsoft.Bcl.AsyncInterfaces (>= 5.0.0)
- Microsoft.Extensions.DependencyInjection (>= 5.0.0)
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 5.0.0)
- Microsoft.Extensions.Http (>= 5.0.0)
- Microsoft.Extensions.Logging (>= 5.0.0)
- Microsoft.Extensions.Logging.Abstractions (>= 5.0.0)
- Microsoft.Extensions.Options (>= 5.0.0)
- Microsoft.Extensions.Primitives (>= 5.0.0)
- Minio (>= 7.0.0)
- System.IO.Hashing (>= 6.0.0)
- System.IO.Pipelines (>= 5.0.1)
-
net8.0
- Bitzsoft.Integrations.Compatibility (>= 1.0.0-alpha.7)
- Bitzsoft.Integrations.FileStorage (>= 1.0.0-alpha.7)
- Microsoft.Extensions.Http (>= 10.0.9)
- Minio (>= 7.0.0)
NuGet packages (2)
Showing the top 2 NuGet packages that depend on Bitzsoft.Integrations.FileStorage.Minio:
| Package | Downloads |
|---|---|
|
Bitzsoft.Integrations.All
Bitzsoft 第三方集成聚合包 — 包含全部 Integration 模块 |
|
|
Bitzsoft.Integrations.FileStorage.All
多云文件存储聚合包 — 包含 Aliyun / Azure / AWS / MinIO / 腾讯云 / 华为云 / 七牛云 / 又拍云 / 金山云 / NAS 全部实现 |
GitHub repositories
This package is not used by any popular GitHub repositories.
| Version | Downloads | Last Updated |
|---|---|---|
| 1.0.0-alpha.7 | 58 | 6/16/2026 |
| 1.0.0-alpha.6 | 66 | 6/16/2026 |
| 1.0.0-alpha.5 | 57 | 6/14/2026 |
| 1.0.0-alpha.3 | 59 | 6/7/2026 |