10个版本

0.2.4 2023年12月26日
0.2.3 2023年5月23日
0.2.2 2022年12月22日
0.2.1 2022年11月1日
0.1.2 2022年6月9日

#148 in 认证

Download history 31/week @ 2024-03-11 15/week @ 2024-03-18 19/week @ 2024-03-25 74/week @ 2024-04-01 26/week @ 2024-04-08 17/week @ 2024-04-15 30/week @ 2024-04-22 30/week @ 2024-04-29 26/week @ 2024-05-06 28/week @ 2024-05-13 44/week @ 2024-05-20 48/week @ 2024-05-27 29/week @ 2024-06-03 37/week @ 2024-06-10 35/week @ 2024-06-17 58/week @ 2024-06-24

每月下载量 164
用于 7 个crates (3 直接)

MIT 许可证

97KB
2K SLoC

Qiniu-Credential

qiniu-credential docs.rs Run Test Cases GitHub release MIT licensed

概述

负责存储调用七牛API所必需的认证信息,提供 CredentialProvider 方便扩展获取认证信息的方式。 同时提供阻塞接口和异步接口(异步接口需要启用 async 功能)。 提供 CredentialProvider 的多个实现方式,例如:

  • GlobalCredentialProvider 使用全局变量配置的认证信息
  • EnvCredentialProvider 使用环境变量配置的认证信息
  • ChainCredentialsProvider 配置多个 CredentialProvider 形成认证信息串,遍历找寻第一个可用的认证信息

不启用异步接口

[dependencies]
qiniu-credential = "0.2.1"

启用异步接口

[dependencies]
qiniu-credential = { version = "0.2.1", features = ["async"] }

代码示例

阻塞代码示例

计算七牛鉴权签名 V1

use qiniu_credential::{Credential, HeaderValue, prelude::*};
use mime::APPLICATION_WWW_FORM_URLENCODED;
use std::io::Cursor;

let credential = Credential::new("abcdefghklmnopq", "1234567890");
let authorization = credential
    .get(Default::default())?
    .authorization_v1_for_request_with_body_reader(
        &"http://upload.qiniup.com/".parse()?,
        Some(&HeaderValue::from_str(APPLICATION_WWW_FORM_URLENCODED.as_ref())?),
        &mut Cursor::new(b"name=test&language=go"),
    );

计算七牛鉴权签名 V2

use qiniu_credential::{Credential, Method, HeaderMap, HeaderValue, prelude::*};
use http::header::CONTENT_TYPE;
use mime::APPLICATION_JSON;
use std::io::Cursor;

let credential = Credential::new("abcdefghklmnopq", "1234567890");
let mut headers = HeaderMap::new();
headers.insert(CONTENT_TYPE, HeaderValue::from_str(APPLICATION_JSON.as_ref())?);
let authorization = credential
    .get(Default::default())?
    .authorization_v2_for_request_with_body_reader(
        &Method::GET,
        &"http://upload.qiniup.com/".parse()?,
        &headers,
        &mut Cursor::new(b"{\"name\":\"test\"}"),
    );

计算下载地址签名

use qiniu_credential::{Credential, prelude::*};
use std::time::Duration;

let credential = Credential::new("abcdefghklmnopq", "1234567890");
let url = "http://www.qiniu.com/?go=1".parse()?;
let url = credential
    .get(Default::default())?
    .sign_download_url(url, Duration::from_secs(3600));
println!("{}", url);

异步代码示例

计算七牛鉴权签名 V1

use qiniu_credential::{Credential, HeaderValue, prelude::*};
use mime::APPLICATION_WWW_FORM_URLENCODED;
use std::io::Cursor;

let credential = Credential::new("abcdefghklmnopq", "1234567890");
let authorization = credential
    .async_get(Default::default()).await?
    .authorization_v1_for_request_with_async_body_reader(
        &"http://upload.qiniup.com/".parse()?,
        Some(&HeaderValue::from_str(APPLICATION_WWW_FORM_URLENCODED.as_ref())?),
        &mut Cursor::new(b"name=test&language=go"),
    ).await?;

计算七牛鉴权签名 V2

use qiniu_credential::{Credential, Method, HeaderMap, HeaderValue, prelude::*};
use http::header::CONTENT_TYPE;
use mime::APPLICATION_JSON;
use std::io::Cursor;

let credential = Credential::new("abcdefghklmnopq", "1234567890");
let mut headers = HeaderMap::new();
headers.insert(CONTENT_TYPE, HeaderValue::from_str(APPLICATION_JSON.as_ref())?);
let authorization = credential
    .async_get(Default::default()).await?
    .authorization_v2_for_request_with_async_body_reader(
        &Method::GET,
        &"http://upload.qiniup.com/".parse()?,
        &headers,
        &mut Cursor::new(b"{\"name\":\"test\"}"),
    ).await?;

最低支持的Rust版本(MSRV)

1.70.0

联系我们

  • 如有需要帮助,请提交工单(在门户右侧点击咨询和建议提交工单,或者直接向 [email protected] 发送邮件)
  • 如有任何问题,可以到问答社区提问,问答社区
  • 更详细的文档,见官方文档站
  • 如果发现了bug, 欢迎提交 Issue
  • 如果有功能需求,欢迎提交 Issue
  • 如果要提交代码,欢迎提交 Pull Request
  • 欢迎关注我们的微信 微博,及时获取动态信息。

代码许可

本项目采用MIT许可

依赖

~1.7–2.6MB
~52K SLoC