在OAS服务协议中,下载是通过提交任务(Job)的形式存在的,按业务类型分为三类,分别是:
/**
 * 提交请求下载archive任务请求
 * @param vaultName 目标vault名称
 * @param archiveId 需下载的archiveId
 * @return 返回Job信息跟踪器,可用来获取Job信息,如jobId,eTag校验信息
 * @throws OASClientException
 * @throws OASServerException
 */
public JobMonitor downloadAsync(String vaultName, String archiveId)
    throws OASClientException, OASServerException;
/**
 * 提交请求下载archive任务请求
 * @param vaultName 目标vault名称
 * @param archiveId 需下载的archiveId
 * @param description 备注
 * @return 返回Job信息跟踪器,可用来获取Job信息,如jobId,eTag校验信息
 * @throws OASClientException
 * @throws OASServerException
 */
public JobMonitor downloadAsync(String vaultName, String archiveId, String description)
    throws OASClientException, OASServerException;
/**
 * 提交请求下载archive任务请求
 * @param vaultName 目标vault名称
 * @param archiveId 需下载的archiveId
 * @param range 指定要下载的范围
 * @return 返回Job信息跟踪器,可用来获取Job信息,如jobId,eTag校验信息
 * @throws OASClientException
 * @throws OASServerException
 */
public JobMonitor downloadWithRangeAsync(String vaultName, String archiveId, Range range)
    throws OASClientException, OASServerException;
/**
 * 提交请求下载archive任务请求
 * @param vaultName 目标vault名称
 * @param archiveId 需下载的archiveId
 * @param range 指定要下载的范围
 * @param description 备注
 * @return 返回Job信息跟踪器,可用来获取Job信息,如jobId,eTag校验信息
 * @throws OASClientException
 * @throws OASServerException
 */
public JobMonitor downloadWithRangeAsync(
    String vaultName, String archiveId, Range range, String description)
    throws OASClientException, OASServerException;
JobMonitor jobMonitor = archiveManager.downloadAsync(
    "[yourVaultName]", "[yourArchiveId]");
// JobMonitor提供的阻塞等待方法,直到Job状态完结
// 实际场景中,不建议如此使用,因为Job的执行时间在几分钟到4小时不等
// 长时间阻塞程序不是明智的做法
jobMonitor.waitUntilFinished();
System.out.println("Job has been comitted successfully.");
System.out.println("Your JobId=" + jobMonitor.getJobId());
/**
 * 根据vault名称获得vault的目录信息
 * @param vaultName 目标vault名称
 * @return
 */
public JobMonitor downloadInventoryAsync(String vaultName)
    throws OASClientException, OASServerException;
/**
 * 根据vault名称获得vault的目录信息
 * @param vaultName 目标vault名称
 * @param description 备注
 * @return
 * @throws OASClientException
 * @throws OASServerException
 */
public JobMonitor downloadInventoryAsync(
    String vaultName, String description)
    throws OASClientException, OASServerException;
/**
 * 下载Job输出到文件,只有当Job的状态是Succeeded或Failed(到达终结状态)时,才能执行此操作
 * @param vaultName 目标vault名称
 * @param jobId 要下载的jobId
 * @param file 保存的目标文件
 * @return 保存的目标文件的句柄对象
 * @throws OASClientException
 * @throws OASServerException
 */
public File downloadJobOutput(String vaultName, String jobId, File file)
    throws OASClientException, OASServerException;
/**
 * 下载Job输出到文件,只有当Job的状态是Succeeded或Failed(到达终结状态)时,才能执行此操作
 * @param vaultName 目标vault名称
 * @param jobId 要下载的jobId
 * @param file 保存的目标文件
 * @return 异步任务传输对象,可获得传输信息
 * @throws OASClientException
 * @throws OASServerException
 */
public BaseTransfer<File> downloadJobOutputAsync(
    String vaultName, String jobId, File file)
       throws OASClientException, OASServerException;
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。