设置对象属性
您可以在上传对象时设置对象属性。对象属性包含对象MD5值(用于校验)、对象存储类型、对象自定义元数据。对象属性可以在多种上传方式下(流式上传、文件上传、分段上传),或复制对象时进行设置。
对象属性详细说明见下表:
|
名称 |
描述 |
默认值 |
|---|---|---|
|
contentMD5 |
对象数据的MD5值(经过Base64编码),提供给OBS服务端,校验数据完整性。 |
无 |
|
storageClass |
对象的存储类型,不同的存储类型可以满足客户业务对存储性能、成本的不同诉求。默认与桶的存储类型保持一致,可以设置为与桶的存储类型不同。 |
标准存储 |
|
metaDataDict |
用户对上传到桶中对象的自定义属性描述,以便对对象进行自定义管理。 |
无 |
|
contentType |
上传对象时指定的MIME类型,定义对象的类型及网页编码,决定浏览器将以什么形式、什么编码读取对象。 |
二进制流 |
|
customContentType |
上传对象时指定的MIME类型,定义对象的类型及网页编码。区别于contentType参数,customContentType参数允许传入任意字符以指定上传对象的MIME类型。 |
无 |
设置对象MD5值
您可以通过contentMD5来设置对象MD5值。以下代码展示如何设置对象MD5值:
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];
NSString *filePath = [[NSBundle mainBundle]pathForResource:@"fileName" ofType:@"Type"];
//文件上传
OBSPutObjectWithFileRequest *request = [[OBSPutObjectWithFileRequest alloc]initWithBucketName:@"bucketname" objectKey:@"objectname" uploadFilePath:filePath];
//设置对象MD5
request.contentMD5 = @"your md5 which should be encoded by base64"
[client putObject:request completionHandler:^(OBSPutObjectResponse *response, NSError *error){
NSLog(@"%@",response.etag);
}];
- 对象数据的MD5值必须经过Base64编码。
- OBS服务端会将该MD5值与对象数据计算出的MD5值进行对比,如果不匹配则上传失败,返回HTTP 400错误。
- 如果不设置对象的MD5值,OBS服务端会忽略对对象数据的MD5值校验。
设置对象存储类型
您可以通过storageClass来设置对象存储类型。以下代码展示如何设置对象存储类型:
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];
NSString *filePath = [[NSBundle mainBundle]pathForResource:@"fileName" ofType:@"Type"];
//文件上传
OBSPutObjectWithFileRequest *request = [[OBSPutObjectWithFileRequest alloc]initWithBucketName:@"bucketname" objectKey:@"objectname" uploadFilePath:filePath];
// 设置对象存储类型
request.storageClass = OBSStorageClassStandard;
[client putObject:request completionHandler:^(OBSPutObjectResponse *response, NSError *error){
NSLog(@"%@",response.etag);
}];
设置对象自定义元数据
您可以通过metaDataDict来设置对象自定义元数据。以下代码展示如何设置对象自定义元数据:
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];
// 流式上传字符串
OBSPutObjectWithDataRequest *request = [[OBSPutObjectWithDataRequest alloc]initWithBucketName:@"bucketname" objectKey:@"objectname" uploadData:[@"" dataUsingEncoding:NSUTF8StringEncoding]];
// 设置对象元数据
request.metaDataDict = @{@"meta1":@"value1",@"meta2":@"value2"};
[client putObject:request completionHandler:^(OBSPutObjectResponse *response, NSError *error){
NSLog(@"%@",response);
}];
- 在上面设置对象自定义元数据示例代码中,用户自定义了一个名称为“meta1”,值为“value1”的元数据和一个名称为“meta2”,值为“value2”的元数据。
- 一个对象可以有多个元数据,总大小不能超过8KB。
- 对象的自定义元数据可以通过OBSGetObjectMetaDataRequest获取,参见获取对象元数据。
- 使用getObject下载对象时,对象的自定义元数据也会同时下载。
设置对象上传类型
您可以通过contentType来设置对象上传类型。以下代码展示如何通过contentType参数设置对象上传类型:
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];
NSString *filePath = [[NSBundle mainBundle]pathForResource:@"fileName" ofType:@"mp4"];
//文件上传
OBSPutObjectWithFileRequest *request = [[OBSPutObjectWithFileRequest alloc]initWithBucketName:@"bucketname" objectKey:@"objectname" uploadFilePath:filePath];
// 设置对象上传类型
request.contentType = OBSContentTypeMP4;
[client putObject:request completionHandler:^(OBSPutObjectResponse *response, NSError *error){
NSLog(@"%@",response.etag);
}];
|
类型 |
OBS IOS SDK对应枚举值 |
|---|---|
|
video/mp4 |
OBSContentTypeMP4 |
|
text/html |
OBSContentTypeHTML |
|
image/png |
OBSContentTypePNG |
|
image/jpeg |
OBSContentTypeJPEG |
|
image/gif |
OBSContentTypeGIF |
|
application/pdf |
OBSContentTypePDF |
|
audio/mp3 |
OBSContentTypeMP3 |
|
audio/wav |
OBSContentTypeWAV |
|
binary/octet-stream |
OBSContentTypeBinary |
|
video/quicktime |
OBSContentTypeMOV |
|
application/vnd.apple.mpegurl |
OBSContentTypeM3U8 |
您还可以通过customContentType字段来设置对象上传类型,以下代码展示如何通过customContentType参数设置对象上传类型:
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];
NSString *filePath = [[NSBundle mainBundle]pathForResource:@"fileName" ofType:@"mp4"];
//文件上传
OBSPutObjectWithFileRequest *request = [[OBSPutObjectWithFileRequest alloc]initWithBucketName:@"bucketname" objectKey:@"objectname" uploadFilePath:filePath];
// 设置对象上传类型
request.customContentType = @"video/mp4";
[client putObject:request completionHandler:^(OBSPutObjectResponse *response, NSError *error){
NSLog(@"%@",response.etag);
}];
- 当前contentType参数支持指定上表中列出的11种对象类型。如果不设置,默认采用binary/octet-stream类型。
- 区别于contentType参数,customContentType参数支持以字符串形式指定任意对象上传类型。如果不设置,以contentType对应类型为对象最终上传类型。
- 当同时指定了customContentType参数及contentType参数时,对象最终上传类型为customContentType指定的上传类型。