更新时间:2024-04-26 GMT+08:00
分享

下载归档存储对象

开发过程中,您有任何问题可以在github上提交issue,或者在华为云对象存储服务论坛中发帖求助。接口参考文档详细介绍了每个接口的参数和使用方法。

如果要下载归档存储对象,需要先将归档存储对象恢复。恢复归档存储对象的恢复选项可支持两类,见下表:

选项

说明

OBS BrowserJS SDK对应值

快速恢复

恢复耗时1~5分钟。

ObsClient.enums.RestoreTierExpedited

标准恢复

恢复耗时3~5小时。默认值。

ObsClient.enums.RestoreTierStandard

重复恢复归档存储数据时在延长恢复有效期的同时,也将会对恢复时产生的恢复费用进行重复收取。产生的标准存储类别的对象副本有效期将会延长,并且收取延长时间段产生的标准存储副本费用。

您可以通过ObsClient.restoreObject恢复归档存储对象。以下代码展示了如何下载归档存储对象:

// 创建ObsClient实例
var obsClient = new ObsClient({
    // 认证用的ak和sk硬编码到代码中或者明文存储都有很大的安全风险,建议在配置文件或者环境变量中密文存放,使用时解密,确保安全;本示例以ak和sk保存在环境变量中为例,运行本示例前请先在本地环境中设置环境变量AccessKeyID和SecretAccessKey。
    // 前端本身没有process对象,可以使用webpack类打包工具定义环境变量,就可以在代码中运行了。
    // 您可以登录访问管理控制台获取访问密钥AK/SK,获取方式请参见https://support.huaweicloud.com/usermanual-ca/ca_01_0003.html
    access_key_id: process.env.AccessKeyID,
    secret_access_key: process.env.SecretAccessKey,
    // 这里以华北-北京四为例,其他地区请按实际情况填写
    server: 'https://obs.cn-north-4.myhuaweicloud.com'
});

// 恢复归档存储对象
obsClient.restoreObject({
       Bucket : 'bucketname',
       Key : 'objectname',
       Days : 1,
       Tier : obsClient.enums.RestoreTierExpedited
}, function (err, result) {
       if(err){
              console.error('Error-->' + err);
       }else{
              console.log('Status-->' + result.CommonMsg.Status);
              
              // 等待对象恢复
              setTimeout(function () {
                     
                     // 下载对象, 获取对象内容
                     obsClient.getObject({
                           Bucket : 'bucketname',
                           Key : 'objectname'
                     }, function (err, result) {
                            if(err){              
                               console.error('Error-->' + err);       
                            }else{              
                               console.log('Status-->' + result.CommonMsg.Status); 
                               if(result.CommonMsg.Status < 300 && result.InterfaceResult){     
                                   // 读取对象内容                           
                                   console.log('Object Content:');                            
                                   console.log(result.InterfaceResult.Content);   
                               }    
                            }
                     });
              }, 6 * 60 * 1000);
       }
});
  • ObsClient.restoreObject中指定的对象必须是归档存储类型,否则调用该接口会报错。
  • 使用Days参数指定恢复对象保存的时间,取值范围是1~30;使用Tier参数指定恢复选项,表示恢复对象所耗的时间。

相关文档