存储类型转换

本SDK提供CopyObjectCommand类实现存储类型转换,允许在不移动或重新上传文件的情况下更新对象的元数据。完整代码详见 GithubCopyObjectCommand调用的 S3 API 为 CopyObject, 具体参见CopyObject API 文档

参数说明

  • Bucket: 文件所在的存储空间
  • CopySource: 存储空间内的文件路径
  • Key: 文件在存储空间内的名称
  • StorageClass: S3 存储类型
  • MetadataDirective: 复制原有元数据("COPY")或替换为新的元数据("REPLACE")

存储类型转换规则

US3存储类型 S3存储类型 US3对应S3默认存储类型
STANDARD STANDARD
STANDARD_IA
STANDARD
IA ONEZONE_IA
INTELLIGENT_TIERING
REDUCED_REDUNDANCY
ONEZONE_IA
ARCHIVE GLACIER
DEEP_ARCHIVE
GLACIER

示例

执行该示例前请确保配置文件的正确性
以下代码段需要在上下文中运行

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
function UpdateStorageClass() {
    const [bucketName, setBucketName] = useState("");
    const [keyName, setKeyName] = useState("");
    const [storageClass, setStorageClass] = useState("");
    const [updateStatus, setUpdateStatus] = useState("");

    const handleUpdate = async () => {
        if (!bucketName || !keyName || !storageClass) {
            setUpdateStatus("请填写所有字段");
            return;
        }

        const copySource = `${bucketName}/${keyName}`;
        const params = {
            Bucket: bucketName,
            CopySource: copySource,
            Key: keyName,
            StorageClass: storageClass,
            MetadataDirective: 'COPY'
        };

        try {
            const command = new CopyObjectCommand(params);
            const response = await s3.send(command);
            console.log("存储类型更新成功:", response);
            setUpdateStatus("存储类型更新成功!");
        } catch (err) {
            console.error("存储类型更新失败:", err);
            setUpdateStatus("存储类型更新失败");

        }
    };