对象存储服务 OBS-限定条件下载
限定条件下载
下载对象时,可以指定一个或多个限定条件,满足限定条件时则进行下载,否则抛出异常,下载对象失败。
您可以使用的限定条件如下:
参数 |
作用 |
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进行后台下载。