使用Amazon SDK for Java在单个操作中上传档案 - Amazon S3 Glacier
Amazon Web Services 文档中描述的 Amazon Web Services 服务或功能可能因区域而异。要查看适用于中国区域的差异,请参阅中国的 Amazon Web Services 服务入门

本文属于机器翻译版本。若本译文内容与英语原文存在差异,则一律以英文原文为准。

使用Amazon SDK for Java在单个操作中上传档案

二者高级和低级 APIAmazon SDK for Java 提供上传档案的方法。

使用Amazon SDK for Java的高级 API 上传档案

该高级 API 的 ArchiveTransferManager 类提供了您可以用来将档案上传到文件库的 upload 方法。

注意

您可以使用 upload 方法上传小型或大型档案。根据您要上传的档案大小,此方法会确定是在单一操作中上传档案,还是使用分段上传 API 分段上传档案。

例如:使用Amazon SDK for Java的高级 API 上传档案

以下 Java 代码示例将档案上传到文件库 (examplevault)中的美国西部(俄勒冈)区域(us-west-2)。有关受支持的列表Amazon区域和终端节点,请参阅访问 Amazon S3 Glacier er

有关如何运行以下示例的分步说明,请参阅使用 Eclipse 运行 Java 示例。您需要更新目标上传文件库名称和待上传文件名称旁显示的代码。

import java.io.File; import java.io.IOException; import java.util.Date; import com.amazonaws.auth.profile.ProfileCredentialsProvider; import com.amazonaws.services.glacier.AmazonGlacierClient; import com.amazonaws.services.glacier.transfer.ArchiveTransferManager; import com.amazonaws.services.glacier.transfer.UploadResult; public class ArchiveUploadHighLevel { public static String vaultName = "*** provide vault name ***"; public static String archiveToUpload = "*** provide name of file to upload ***"; public static AmazonGlacierClient client; public static void main(String[] args) throws IOException { ProfileCredentialsProvider credentials = new ProfileCredentialsProvider(); client = new AmazonGlacierClient(credentials); client.setEndpoint("https://glacier.us-west-2.amazonaws.com/"); try { ArchiveTransferManager atm = new ArchiveTransferManager(client, credentials); UploadResult result = atm.upload(vaultName, "my archive " + (new Date()), new File(archiveToUpload)); System.out.println("Archive ID: " + result.getArchiveId()); } catch (Exception e) { System.err.println(e); } } }

使用Amazon SDK for Java低级 API 在单个操作中上传档案

该低级 API 为所有档案操作提供了方法。下面是使用 Amazon SDK for Java 上传存档的步骤。

  1. 创建 AmazonGlacierClient 类(客户端)的实例。

    您需要指定Amazon要上传档案的区域。您使用此客户端执行的所有操作都会应用到该Amazon区域。

  2. 通过创建一个 UploadArchiveRequest 类的实例提供请求信息。

    除了您要上传的数据以外,您还需要提供有效负载的校验和(SHA-256 树形哈希)、文件库名称、数据的内容长度和您的账户 ID。

    如果您不提供账户 ID,则系统会使用与您提供来对请求签名的证书相关联的账户 ID。有关更多信息,请参阅使用Amazon SDK for JavaAmazon S3 Glacier

  3. 运行uploadArchive方法中提供请求对象,以参数形式提供请求对象。

    作为响应,Amazon S3 Glacier (S3 Glacier) 返回新上传的档案的档案 ID。

以下 Java 代码段说明了前面的步骤。

AmazonGlacierClient client; UploadArchiveRequest request = new UploadArchiveRequest() .withVaultName("*** provide vault name ***") .withChecksum(checksum) .withBody(new ByteArrayInputStream(body)) .withContentLength((long)body.length); UploadArchiveResult uploadArchiveResult = client.uploadArchive(request); System.out.println("Location (includes ArchiveID): " + uploadArchiveResult.getLocation());

例如:使用Amazon SDK for Java低级 API 在单个操作中上传档案

以下 Java 代码示例使用Amazon SDK for Java将档案上传到文件库 (examplevault)。有关如何运行以下示例的分步说明,请参阅使用 Eclipse 运行 Java 示例。您需要更新目标上传文件库名称和待上传文件名称旁显示的代码。

import java.io.ByteArrayInputStream; import java.io.File; import java.io.FileInputStream; import java.io.IOException; import java.io.InputStream; import com.amazonaws.auth.profile.ProfileCredentialsProvider; import com.amazonaws.services.glacier.AmazonGlacierClient; import com.amazonaws.services.glacier.TreeHashGenerator; import com.amazonaws.services.glacier.model.UploadArchiveRequest; import com.amazonaws.services.glacier.model.UploadArchiveResult; public class ArchiveUploadLowLevel { public static String vaultName = "*** provide vault name ****"; public static String archiveFilePath = "*** provide to file upload ****"; public static AmazonGlacierClient client; public static void main(String[] args) throws IOException { ProfileCredentialsProvider credentials = new ProfileCredentialsProvider(); client = new AmazonGlacierClient(credentials); client.setEndpoint("https://glacier.us-east-1.amazonaws.com/"); try { // First open file and read. File file = new File(archiveFilePath); InputStream is = new FileInputStream(file); byte[] body = new byte[(int) file.length()]; is.read(body); // Send request. UploadArchiveRequest request = new UploadArchiveRequest() .withVaultName(vaultName) .withChecksum(TreeHashGenerator.calculateTreeHash(new File(archiveFilePath))) .withBody(new ByteArrayInputStream(body)) .withContentLength((long)body.length); UploadArchiveResult uploadArchiveResult = client.uploadArchive(request); System.out.println("ArchiveID: " + uploadArchiveResult.getArchiveId()); } catch (Exception e) { System.err.println("Archive not uploaded."); System.err.println(e); } } }