#progress-bar #qiniu #indicatif #qiniu-upload

qiniu-uploader

带进度条的七牛上传库

10个版本

0.1.10 2024年8月10日
0.1.9 2024年8月10日

#2 in #indicatif

Download history 237/week @ 2024-07-29 452/week @ 2024-08-05 81/week @ 2024-08-12

770 每月下载
qiniu-upload-util 中使用

MIT 许可

31KB
593

Crates.io qiniu-uploader

七牛文件上传

封装了七牛直传文件分片上传 v2 版,支持显示上传进度条,由indicatif提供支持.

分片上传时,支持设置分片大小和上传线程数量

使用

默认启用显示进度条

cargo add qiniu-uploader

也可以关闭显示进度条

cargo add qiniu-uploader --no-default-features

use mime::Mime;
use qiniu_uploader::{QiniuRegionEnum, QiniuUploader};
use tokio::fs;

#[tokio::main]
async fn main() -> Result<(), anyhow::Error> {
    let qiniu = QiniuUploader::new(
        "access_key",
        "secret_key",
        "bucket",
        Some(QiniuRegionEnum::Z0),
        false,
    );
    let file = fs::File::open("./Cargo.lock").await?;
    let file_size = file.metadata().await?.len() as usize;
    // 分片上传,支持设置分片大小或上传线程数量
    qiniu
        .clone()
        .part_upload_file(
            "test/Cargo.lock",
            file,
            file_size,
            Some(1024 * 1024 * 50), // 分片大小
            Some(10),               // 上传线程数量
            None,                   // 进度条样式
        )
        .await?;
    // 直传,文件大小应在1GB以内为宜
    let file = fs::File::open("./Cargo.lock").await?;
    qiniu
        .upload_file(
            "test/Cargo.lock.1",
            file,
            mime::APPLICATION_OCTET_STREAM,
            file_size,
            None,
        )
        .await?;
    Ok(())
}

更详细的参数见https://docs.rs/qiniu-uploader/

依赖

~7–19MB
~276K SLoC