@mingto/obs-server
v1.0.40
Published
通用OBS文件上传
Readme
@mingto/obs-server
统一的 OBS 文件上传工具库,旨在简化并高效处理文件上传任务。该工具库会自动判断使用 @mingto/huawei-obs-server、@mingto/aws-obs-server 或 @mingto/minio-v2-obs-server 来完成上传操作。
特性
- 🔄 自动适配:自动识别 OBS 类型并选择对应上传方式
- 📦 统一接口:所有 OBS 类型使用相同的 API 接口
- 🚀 支持大文件:自动分片上传
- 📊 进度监控:实时上传进度回调
- ❌ 取消上传:支持随时取消上传操作
安装
pnpm add @mingto/obs-server快速开始
import obsServer from '@mingto/obs-server'
// 配置全局参数
obsServer.config({
getToken: () => '用户的token',
fileSplitThreshold: 1024 * 1024 * 5
})
// 创建要上传的文件对象
const sourceFile = new File(['hello world'], 'hello.txt', { type: 'text/plain' })
// 创建上传实例
const uploadContext = obsServer.create({
sourceFile,
onProgress: (event) => {
console.log(`上传进度: ${event.percent}%`)
},
onSuccess: (event) => {
console.log('上传成功:', event.fileInfo)
},
onError: (error) => {
console.error('上传失败:', error)
}
})
// 取消上传
// uploadContext.abort()API
obsServer.config(options)
全局配置方法。
| 参数 | 类型 | 必填 | 说明 |
|------|------|------|------|
| getToken | () => string | 是 | 获取上传所需的 token |
| fileSplitThreshold | number | 否 | 文件大小分隔线,默认 5MB |
obsServer.create(options)
创建上传实例。
| 参数 | 类型 | 必填 | 说明 |
|------|------|------|------|
| sourceFile | File | 是 | 要上传的文件对象 |
| partSize | number | 否 | 分片大小,默认 5MB |
| sceneId | '0' \| '1' | 否 | 上传桶的类型,'0' 为私有桶,'1' 为公共桶(默认) |
| onStart | () => void | 否 | 上传开始回调 |
| onProgress | (event) => void | 否 | 上传进度回调 |
| onSuccess | (event) => void | 否 | 上传成功回调 |
| onError | (error) => void | 否 | 上传失败回调 |
| onAbort | () => void | 否 | 取消上传回调 |
| onFinally | () => void | 否 | 上传结束回调 |
注意事项
OBS 类型自动判断:工具库会调用后端
file/config接口获取 OBS 类型- 返回
aws→ 使用@mingto/aws-obs-server - 返回
huawei→ 使用@mingto/huawei-obs-server - 返回
minio→ 使用@mingto/minio-v2-obs-server
- 返回
参数配置:具体参数配置请参考对应工具库的文档
完整文档
更多详细用法请参考 官方文档
许可证
MIT
