Crates.io | rusty-oss |
lib.rs | rusty-oss |
version | 0.2.1 |
source | src |
created_at | 2025-02-07 07:02:52.743178+00 |
updated_at | 2025-02-07 12:57:01.819784+00 |
description | Simple pure Rust Aliyun OSS Client following a Sans-IO approach |
homepage | |
repository | https://github.com/DatawhaleCorp/rusty-oss |
max_upload_size | |
id | 1546589 |
size | 148,824 |
rusty-oss
是一个纯 Rust 编写的对象存储客户端,灵感来源于 rusty-s3 项目。该项目是一个简单的纯 Rust OSS 客户端,使用 OSS 签名版本 4 来进行请求签名。
以下是一个简单的使用示例:
use std::env;
use std::time::Duration;
use rusty_oss::{Bucket, Credentials, OSSAction, UrlStyle};
# env::set_var("ALIYUN_OSS_ACCESS_KEY", "key");
# env::set_var("ALIYUN_OSS_ACCESS_SECRET", "secret");
// setting up a bucket
let endpoint = "https://oss-cn-hangzhou.aliyuncs.com".parse().expect("endpoint is a valid Url");
let path_style = UrlStyle::VirtualHost;
let name = "examplebucket";
let region = "cn-hangzhou";
let bucket = Bucket::new(endpoint, path_style, name, region).expect("Url has a valid scheme and host");
// setting up the credentials
let key = env::var("ALIYUN_OSS_ACCESS_KEY").expect("ALIYUN_OSS_ACCESS_KEY is set and a valid String");
let secret = env::var("ALIYUN_OSS_ACCESS_SECRET").expect("ALIYUN_OSS_ACCESS_SECRET is set and a valid String");
let credentials = Credentials::new(key, secret);
// signing a request
let presigned_url_duration = Duration::from_secs(60 * 60);
let action = bucket.get_object(Some(&credentials), "duck.jpg");
println!("GET {}", action.sign(presigned_url_duration));