复制对象
开发过程中,您有任何问题可以在github上提交issue,或者在华为云对象存储服务论坛中发帖求助。接口参考文档详细介绍了每个接口的参数和使用方法。
复制对象特性用来为OBS上已经存在的对象创建一个副本。
您可以通过ObsClient.CopyObject来复制对象。复制对象时,可重新指定新对象的属性和设置对象权限,且支持条件复制。
- 如果待复制的源对象是归档存储类型,则必须先恢复源对象才能进行复制。
简单复制
以下代码展示了如何进行简单复制:
// 初始化配置参数
ObsConfig config = new ObsConfig();
config.Endpoint = "https://your-endpoint";
// 认证用的ak和sk硬编码到代码中或者明文存储都有很大的安全风险,建议在配置文件或者环境变量中密文存放,使用时解密,确保安全;本示例以ak和sk保存在环境变量中为例,运行本示例前请先在本地环境中设置环境变量AccessKeyID和SecretAccessKey。
// 您可以登录访问管理控制台获取访问密钥AK/SK,获取方式请参见https://support.huaweicloud.com/usermanual-ca/ca_01_0003.html
string accessKey= Environment.GetEnvironmentVariable("AccessKeyID", EnvironmentVariableTarget.Machine);
string secretKey= Environment.GetEnvironmentVariable("SecretAccessKey", EnvironmentVariableTarget.Machine);
// 创建ObsClient实例
ObsClient client = new ObsClient(accessKey, secretKey, config);
// 复制对象
try
{
CopyObjectRequest request = new CopyObjectRequest();
request.SourceBucketName = "sourcebucketname";
request.SourceObjectKey = "sourceobjectname";
request.BucketName = "destbucketname";
request.ObjectKey = "destobjectName";
CopyObjectResponse response = client.CopyObject(request);
Console.WriteLine("Copy object response: {0}", response.StatusCode);
}
catch (ObsException ex)
{
Console.WriteLine("ErrorCode: {0}", ex.ErrorCode);
Console.WriteLine("ErrorMessage: {0}", ex.ErrorMessage);
}
重写对象属性
以下代码展示了如何在复制对象时重写对象属性:
// 初始化配置参数
ObsConfig config = new ObsConfig();
config.Endpoint = "https://your-endpoint";
// 认证用的ak和sk硬编码到代码中或者明文存储都有很大的安全风险,建议在配置文件或者环境变量中密文存放,使用时解密,确保安全;本示例以ak和sk保存在环境变量中为例,运行本示例前请先在本地环境中设置环境变量AccessKeyID和SecretAccessKey。
// 您可以登录访问管理控制台获取访问密钥AK/SK,获取方式请参见https://support.huaweicloud.com/usermanual-ca/ca_01_0003.html
string accessKey= Environment.GetEnvironmentVariable("AccessKeyID", EnvironmentVariableTarget.Machine);
string secretKey= Environment.GetEnvironmentVariable("SecretAccessKey", EnvironmentVariableTarget.Machine);
// 创建ObsClient实例
ObsClient client = new ObsClient(accessKey, secretKey, config);
// 重写对象属性
try
{
CopyObjectRequest request = new CopyObjectRequest();
request.SourceBucketName = "sourcebucketname";
request.SourceObjectKey = "sourceobjectname";
request.BucketName = "destbucketname";
request.ObjectKey = "destobjectName";
request.StorageClass = StorageClassEnum.Warm;
request.ContentType = "image/jpeg";
request.MetadataDirective = MetadataDirectiveEnum.Replace;
CopyObjectResponse response = client.CopyObject(request);
Console.WriteLine("Copy object response: {0}", response.StatusCode);
}
catch (ObsException ex)
{
Console.WriteLine("ErrorCode: {0}", ex.ErrorCode);
Console.WriteLine("ErrorMessage: {0}", ex.ErrorMessage);
}
限定条件复制
复制对象时,可以指定一个或多个限定条件,满足限定条件时则进行复制,否则抛出异常,复制对象失败。
您可以使用的限定条件如下:
|
参数 |
作用 |
OBS .NET SDK对应属性 |
|---|---|---|
|
Copy-Source-If-Modified-Since |
如果源对象在指定的时间后有修改,则进行复制,否则抛出异常。 |
CopyObjectRequest.IfModifiedSince |
|
Copy-Source-If-Unmodified-Since |
如果源对象在指定的时间后没有修改,则进行复制,否则抛出异常。 |
CopyObjectRequest.IfUnmodifiedSince |
|
Copy-Source-If-Match |
如果源对象的ETag值与该参数值相同,则进行复制,否则抛出异常。 |
CopyObjectRequest.IfMatch |
|
Copy-Source-If-None-Match |
如果源对象的ETag值与该参数值不相同,则进行复制,否则抛出异常。 |
CopyObjectRequest.IfNoneMatch |
- 源对象的ETag值是指源对象数据的MD5校验值。
- 如果包含IfUnmodifiedSince并且不符合,或者包含IfMatch并且不符合,或者包含IfModifiedSince并且不符合,或者包含IfNoneMatch并且不符合,则复制失败,抛出异常中HTTP状态码为:412 precondition failed。
- IfModifiedSince和IfNoneMatch可以一起使用;IfUnmodifiedSince和IfMatch可以一起使用。
以下代码展示了如何进行限定条件复制:
// 初始化配置参数
ObsConfig config = new ObsConfig();
config.Endpoint = "https://your-endpoint";
// 认证用的ak和sk硬编码到代码中或者明文存储都有很大的安全风险,建议在配置文件或者环境变量中密文存放,使用时解密,确保安全;本示例以ak和sk保存在环境变量中为例,运行本示例前请先在本地环境中设置环境变量AccessKeyID和SecretAccessKey。
// 您可以登录访问管理控制台获取访问密钥AK/SK,获取方式请参见https://support.huaweicloud.com/usermanual-ca/ca_01_0003.html
string accessKey= Environment.GetEnvironmentVariable("AccessKeyID", EnvironmentVariableTarget.Machine);
string secretKey= Environment.GetEnvironmentVariable("SecretAccessKey", EnvironmentVariableTarget.Machine);
// 创建ObsClient实例
ObsClient client = new ObsClient(accessKey, secretKey, config);
// 限定条件复制
try
{
CopyObjectRequest request = new CopyObjectRequest();
request.SourceBucketName = "sourcebucketname";
request.SourceObjectKey = "sourceobjectname";
request.BucketName = "destbucketname";
request.ObjectKey = "destobjectName";
request.IfModifiedSince = new DateTime(2018, 3, 10, 12, 00, 00);
CopyObjectResponse response = client.CopyObject(request);
Console.WriteLine("Copy object response: {0}", response.StatusCode);
}
catch (ObsException ex)
{
Console.WriteLine("ErrorCode: {0}", ex.ErrorCode);
Console.WriteLine("ErrorMessage: {0}", ex.ErrorMessage);
}
重写对象ACL
以下代码展示了如何在复制对象时重写对象ACL:
// 初始化配置参数
ObsConfig config = new ObsConfig();
config.Endpoint = "https://your-endpoint";
// 认证用的ak和sk硬编码到代码中或者明文存储都有很大的安全风险,建议在配置文件或者环境变量中密文存放,使用时解密,确保安全;本示例以ak和sk保存在环境变量中为例,运行本示例前请先在本地环境中设置环境变量AccessKeyID和SecretAccessKey。
// 您可以登录访问管理控制台获取访问密钥AK/SK,获取方式请参见https://support.huaweicloud.com/usermanual-ca/ca_01_0003.html
string accessKey= Environment.GetEnvironmentVariable("AccessKeyID", EnvironmentVariableTarget.Machine);
string secretKey= Environment.GetEnvironmentVariable("SecretAccessKey", EnvironmentVariableTarget.Machine);
// 创建ObsClient实例
ObsClient client = new ObsClient(accessKey, secretKey, config);
// 重写对象ACL
try
{
CopyObjectRequest request = new CopyObjectRequest();
request.SourceBucketName = "sourcebucketname";
request.SourceObjectKey = "sourceobjectname";
request.BucketName = "destbucketname";
request.ObjectKey = "destobjectName";
request.CannedAcl = CannedAclEnum.PublicRead;
CopyObjectResponse response = client.CopyObject(request);
Console.WriteLine("Copy object response: {0}", response.StatusCode);
}
catch (ObsException ex)
{
Console.WriteLine("ErrorCode: {0}", ex.ErrorCode);
Console.WriteLine("ErrorMessage: {0}", ex.ErrorMessage);
}