对象存储服务 OBS-限定条件下载

时间:2025-02-12 15:02:06

限定条件下载

下载对象时,可以指定一个或多个限定条件,满足限定条件时则进行下载,否则抛出异常,下载对象失败。

您可以使用的限定条件如下:

参数

作用

OBS iOS SDK对应方法

ifModifiedSince

如果对象在指定的时间后有修改,则返回对象内容,否则返回错误。

request.ifModifiedSince

ifUnmodifiedSince

如果对象在指定的时间后没有修改,则返回对象内容,否则返回错误。

request.ifUnmodifiedSince

ifETagMatch

如果对象的ETag值与该参数值相同,则返回对象内容,否则抛出异常。

request.ifETagMatch

ifETagNoneMatch

如果对象的ETag值与该参数值不相同,则返回对象内容,否则抛出异常。

request.ifETagNoneMatch

  • 对象的ETag值是指对象数据的MD5校验值。
  • 如果限制条件不符合,则会返回错误preconditionFailed。

以下代码展示了如何进行限定条件下载:

static OBSClient *client;NSString *endPoint = @"your-endpoint";// 认证用的ak和sk硬编码到代码中或者明文存储都有很大的安全风险,建议在配置文件或者环境变量中密文存放,使用时解密,确保安全;本示例以ak和sk保存在环境变量中为例,运行本示例前请先在本地环境中设置环境变量AccessKeyID和SecretAccessKey。// 您可以登录访问管理控制台获取访问密钥AK/SK,获取方式请参见https://support.huaweicloud.com/usermanual-ca/ca_01_0003.htmlchar* ak_env = getenv("AccessKeyID");char* sk_env = getenv("SecretAccessKey");NSString *AK = [NSString stringWithUTF8String:ak_env];NSString *SK = [NSString stringWithUTF8String:sk_env];    // 初始化身份验证OBSStaticCredentialProvider *credentialProvider = [[OBSStaticCredentialProvider alloc] initWithAccessKey:AK secretKey:SK];    //初始化服务配置OBSServiceConfiguration *conf = [[OBSServiceConfiguration alloc] initWithURLString:endPoint credentialProvider:credentialProvider];    // 初始化clientclient = [[OBSClient alloc] initWithConfiguration:conf];    // 流式下载OBSGetObjectToDataRequest *request = [[OBSGetObjectToDataRequest alloc]initWithBucketName:@"bucketname" objectKey:@"objectname"];    // 限定条件request.ifModifiedSince = [[OBSUtils getDateFormatterRFC1123]dateFromString:@"Mon, 18 Dec 2017 03:50:49 GMT"];// Etag相等request.ifETagMatch = @"123223";        // 下载进度request.downloadProgressBlock = ^(int64_t bytesWritten, int64_t totalBytesWritten, int64_t totalBytesExpectedToWrite) {    NSLog(@"%0.1f%%",(float)(totalBytesWritten)*100/(float)totalBytesExpectedToWrite);};    // 下载的数据__block NSMutableData *objectData = [NSMutableData new];request.onReceiveDataBlock = ^(NSData *data) {    [objectData appendData:data];};    // 下载结果[client getObject:request completionHandler:^(OBSGetObjectResponse *response, NSError *error){    NSLog(@"%@",response);}] ;

当使用OBSGetObjectToFileRequest时,可以设置background属性为YES进行后台下载。

support.huaweicloud.com/sdk-ios-devg-obs/obs_27_0504.html