TosClient 在向服务端发起请求时,默认会对请求 header 里包含签名。SDK 也支持构造带签名的 URL,您可直接用该 URL 发起 HTTP 请求,也可以将该 URL 共享给第三方实现访问授权。本文以使用预签名的 URL 上传对象和下载对象为例,如果您有其他需求,您可以参考本文设置。
生成用于上传的预签名 URL 示例。
#include "TosClientV2.h"
using namespace VolcengineTos;
int main(void)
{
// 初始化 TOS 账号信息
// Your Region 填写 Bucket 所在 Region
std::string region = "Your Region";
std::string accessKey = std::getenv("TOS_ACCESS_KEY");
std::string secretKey = std::getenv("TOS_SECRET_KEY");
// 填写 Bucket 名称,例如 examplebucket
std::string bucketName = "examplebucket";
// 填写 Object 完整路径,完整路径中请不要包含 Bucket 的名称,例如 exampledir/exampleobject.txt 对象
std::string objectName = "exampledir/exampleobject.txt";
// 初始化网络等资源
InitializeClient();
// 创建交互的 client
TosClientV2 client(region, accessKey, secretKey);
// 设置预签名 URL 有效时间,单位:秒,
int64_t expires = 86400;
// 生成预签名 URL
PreSignedURLInput input(HttpMethodType::Put,bucketName,objectName,expires);
// 设置自定义endpoint
// input.setAlternativeEndpoint("Your Alternative Endpoint");
input.set
auto output = client.preSignedURL(input);
if(!output.isSuccess()){
// 异常处理
std::cout << "GeneratePreSignedUrl failed." << output.error().String() << std::endl;
// 释放网络等资源
CloseClient();
return -1;
}
std::cout << "GeneratePreSignedUrl Success, Gen Url:"<< output.result().getSignUrl() << std::endl;
// 释放网络等资源
CloseClient();
return 0;
}
// 生成的 url 示例
// http://examplebucket.{endpoint/host}/exampledir/exampleobject.txt?X-Tos-Algorithm=TOS4-HMAC-SHA256&X-Tos-Credential={xxx}/{date}/{region}/tos/request&X-Tos-Date=20220922T103306Z&X-Tos-Expires=86400&X-Tos-Signature={yyy}&X-Tos-SignedHeaders=host
生成用于下载的预签名 URL 示例。
#include "TosClientV2.h"
using namespace VolcengineTos;
int main(void)
{
// 初始化 TOS 账号信息
// Your Region 填写 Bucket 所在 Region
std::string region = "Your Region";
std::string accessKey = std::getenv("TOS_ACCESS_KEY");
std::string secretKey = std::getenv("TOS_SECRET_KEY");
// 填写 Bucket 名称,例如 examplebucket
std::string bucketName = "examplebucket";
// 填写 Object 完整路径,完整路径中请不要包含 Bucket 的名称,例如 exampledir/exampleobject.txt 对象
std::string objectName = "exampledir/exampleobject.txt";
// 初始化网络等资源
InitializeClient();
// 创建交互的 client
TosClientV2 client(region, accessKey, secretKey);
// 设置预签名 URL 有效时间,单位:秒,
int64_t expires = 86400;
// 生成预签名 URL
PreSignedURLInput input(HttpMethodType::Get,bucketName,objectName,expires);
auto output = client.preSignedURL(input);
if(!output.isSuccess()){
// 异常处理
std::cout << "GeneratePreSignedUrl failed." << output.error().String() << std::endl;
// 释放网络等资源
CloseClient();
return -1;
}
std::cout << "GeneratePreSignedUrl Success, Gen Url:"<< output.result().getSignUrl() << std::endl;
// 释放网络等资源
CloseClient();
return 0;
}
// 生成的 url 示例
// http://examplebucket.{endpoint/host}/exampledir/exampleobject.txt?X-Tos-Algorithm=TOS4-HMAC-SHA256&X-Tos-Credential={xxx}/{date}/{region}/tos/request&X-Tos-Date=20220922T103306Z&X-Tos-Expires=86400&X-Tos-Signature={yyy}&X-Tos-SignedHeaders=host
关于 URL 包含签名的详细信息,请参见 URL 中包含签名。