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