对象存储服务 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.html char* 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]; // 初始化client client = [[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进行后台下载。