如果仅需要文件中的部分数据,您可以使用范围下载,下载指定范围内的数据。
指定正常的下载范围
以下代码用于指定正常的下载范围来下载文件:
#include <alibabacloud/oss/OssClient.h> using namespace AlibabaCloud::OSS; int main(void) { /* 初始化OSS账号信息 */ std::string AccessKeyId = "yourAccessKeyId"; std::string AccessKeySecret = "yourAccessKeySecret"; std::string Endpoint = "yourEndpoint"; std::string BucketName = "yourBucketName"; std::string ObjectName = "yourObectName "; /* 初始化网络等资源 */ InitializeSdk(); ClientConfiguration conf; OssClient client(Endpoint, AccessKeyId, AccessKeySecret, conf ); /* 获取文件 */ GetObjectRequest request(BucketName, ObjectName); /* 设置下载范围 */ request.setRange(0, 1); auto outcome = client.GetObject(request); if (!outcome.isSuccess ()) { /* 异常处理 */ std::cout << "getObject fail" << ",code:" << outcome.error().Code() << ",message:" << outcome.error().Message() << ",requestId:" << outcome.error().RequestId() << std::endl; ShutdownSdk(); return -1; } /* 释放网络等资源 */ ShutdownSdk(); return 0; }
指定异常的下载范围
假设现有大小为1000 Bytes的Object,则指定的正常下载范围应为0~999。如果指定范围不在有效区间,会导致Range不生效,响应返回值为200,并传送整个Object内容。请求不合法的示例及返回说明如下:
- 若指定了Range: bytes=500~2000,此时范围末端取值不在有效区间,返回整个文件的内容,且HTTP Code为200。
- 若指定了Range: bytes=1000~2000,此时范围首端取值不在有效区间,返回整个文件的内容,且HTTP Code为200。
兼容行为范围下载
在请求中增加请求头x-oss-range-behavior:standard,则改变指定范围不在有效区间时OSS的下载行为。假设现有大小为1000 Bytes的Object,
- 若指定了Range: bytes=500~2000,此时范围末端取值不在有效区间,返回500~999字节范围内容,且HTTP Code为206。
- 若指定了Range: bytes=1000~2000,此时范围首端取值不在有效区间,返回HTTP Code为416,错误码为InvalidRange。
以下代码用于兼容行为范围下载:
#include <alibabacloud/oss/OssClient.h> using namespace AlibabaCloud::OSS; int main(void) { /* 初始化OSS账号信息 */ std::string AccessKeyId = "yourAccessKeyId"; std::string AccessKeySecret = "yourAccessKeySecret"; std::string Endpoint = "yourEndpoint"; std::string BucketName = "yourBucketName"; /* 指定大小为1000 Bytes的文件 */ std::string ObjectName = "yourObectName "; /* 初始化网络等资源 */ InitializeSdk(); ClientConfiguration conf; OssClient client(Endpoint, AccessKeyId, AccessKeySecret, conf ); /* 获取文件 */ GetObjectRequest request(BucketName, ObjectName); /* 设置下载范围 */ /* 指定兼容行为 */ /* 范围末端取值不在有效区间,返回500~999字节范围内容,且HTTP Code为206 */ request.setRange(500, 2000, true); auto outcome = client.GetObject(request); /* 范围首端取值不在有效区间,则会抛出异常。返回HTTP Code为416,错误码为InvalidRange */ request.setRange(1000, 2000, true); outcome = client.GetObject(request); if (!outcome.isSuccess ()) { /* 异常处理 */ std::cout << "getObject fail" << ",code:" << outcome.error().Code() << ",message:" << outcome.error().Message() << ",requestId:" << outcome.error().RequestId() << std::endl; ShutdownSdk(); return -1; } /* 释放网络等资源 */ ShutdownSdk(); return 0; }