简单上传

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

参数说明

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

示例

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

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("文件上传失败");
          
        }
    };
}