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

时间:2024-12-09 15:46:28

限定条件下载

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

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

参数

作用

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进行后台下载。

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