指定存储类型上传

本SDK提供PutObjectCommand类用于指定存储类型上传操作,大文件(5G以上)请使用分片上传,完整代码详见 GithubPutObjectCommand调用的 S3 API 为 PutObject, 具体参见PutObject API 文档

参数说明

  • Bucket: 文件上传后所在的存储空间
  • Key: 文件上传后在存储空间里的名称
  • Body: 待上传的文件全路径
  • StorageClass: S3 存储类型

存储类型转换规则

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
33
34
function UploadFile() {
    const [selectedFile, setSelectedFile] = useState(null);
    const [bucketName, setBucketName] = useState("");
    const [keyName, setKeyName] = useState("");
    const [storageClass, setStorageClass] = useState("");
    const [uploadStatus, setUploadStatus] = useState("");

    const handleFileInput = (event) => {
        setSelectedFile(event.target.files[0]);
    };

    const handleUpload = async () => {
        if (!selectedFile || !bucketName || !keyName) {
            setUploadStatus("请输入桶名,文件,和文件名");
            return; }
        const params = {
            Bucket: bucketName,
            Key: keyName,
            Body: selectedFile,};
        if (storageClass) {
            params.StorageClass = storageClass;
        }
        try {
            const command = new PutObjectCommand(params);
            const response = await s3.send(command);
            console.log("文件上传成功:", response);
            setUploadStatus("文件上传成功!");
        } catch (err) {
            console.error("文件上传失败:", err);
            setUploadStatus("文件上传失败");

        }
    };
}