普通上传是指通过 putObject 方法上传单个对象(Object),支持上传字符串(字符流)、上传 Bytes(Bytes 流)、上传网络流和上传本地文件四种形式。
tos:PutObject
权限,具体操作,请参见权限配置指南。您可以通过以下示例代码,使用 putObject 接口,上传字符串数据到 TOS 指定 example_dir
目录下的 example.txt
文件。
// 导入 SDK, 当 TOS Node.JS SDK 版本小于 2.5.2 请把下方 TosClient 改成 TOS 导入 import { TosClient, TosClientError, TosServerError } from '@volcengine/tos-sdk'; // 创建客户端 const client = new TosClient({ accessKeyId: process.env['TOS_ACCESS_KEY'], accessKeySecret: process.env['TOS_SECRET_KEY'], region: "Provide your region", // 填写 Bucket 所在地域。以华北2(北京)为例,则 "Provide your region" 填写为 cn-beijing。 endpoint: "Provide your endpoint", // 填写域名地址 }); function handleError(error) { if (error instanceof TosClientError) { console.log('Client Err Msg:', error.message); console.log('Client Err Stack:', error.stack); } else if (error instanceof TosServerError) { console.log('Request ID:', error.requestId); console.log('Response Status Code:', error.statusCode); console.log('Response Header:', error.headers); console.log('Response Err Code:', error.code); console.log('Response Err Msg:', error.message); } else { console.log('unexpected exception, message: ', error); } } async function main() { try { const bucketName = 'node-sdk-test-bucket'; const objectName = 'example_dir/example.txt'; // 上传对象 await client.putObject({ bucket: bucketName, key: objectName, // 将字符串 "Hello TOS" 上传到指定 example_dir 目录下的 example.txt body: Buffer.from('Hello TOS'), }); // 查询刚刚上传对象的大小 const { data } = await client.headObject({ bucket: bucketName, key: objectName, }); // object size: 9 console.log('object size:', data['content-length']); } catch (error) { handleError(error); } } main();
您可以通过以下示例代码,使用 putObject 接口上传网络流数据到 TOS 指定 example_dir
目录下的 example.txt
文件。
// 导入 SDK, 当 TOS Node.JS SDK 版本小于 2.5.2 请把下方 TosClient 改成 TOS 导入 import { TosClient, TosClientError, TosServerError } from '@volcengine/tos-sdk'; import https from 'https'; // 创建客户端 const client = new TosClient({ accessKeyId: process.env['TOS_ACCESS_KEY'], accessKeySecret: process.env['TOS_SECRET_KEY'], region: "Provide your region", // 填写 Bucket 所在地域。以华北2(北京)为例,则 "Provide your region" 填写为 cn-beijing。 endpoint: "Provide your endpoint", // 填写域名地址 }); function handleError(error) { if (error instanceof TosClientError) { console.log('Client Err Msg:', error.message); console.log('Client Err Stack:', error.stack); } else if (error instanceof TosServerError) { console.log('Request ID:', error.requestId); console.log('Response Status Code:', error.statusCode); console.log('Response Header:', error.headers); console.log('Response Err Code:', error.code); console.log('Response Err Msg:', error.message); } else { console.log('unexpected exception, message: ', error); } } async function main() { try { const bucketName = 'node-sdk-test-bucket'; const objectName = 'example_dir/example.txt'; // 从网络流中获取数据 const req = https.get('https://www.volcengine.com/'); const res = await new Promise((resolve) => req.on('response', resolve)); // 上传对象 await client.putObject({ bucket: bucketName, key: objectName, body: res, }); // 查询刚刚上传对象的大小 const { data } = await client.headObject({ bucket: bucketName, key: objectName, }); console.log('object size:', data['content-length']); } catch (error) { handleError(error); } } main();
您可以通过以下示例代码,使用 putObject 接口,将指定路径上的文件上传到 TOS 指定 example_dir
目录下的 example.txt
文件。
// 导入 SDK, 当 TOS Node.JS SDK 版本小于 2.5.2 请把下方 TosClient 改成 TOS 导入 import { TosClient, TosClientError, TosServerError } from '@volcengine/tos-sdk'; import fs from 'fs'; // 创建客户端 const client = new TosClient({ accessKeyId: process.env['TOS_ACCESS_KEY'], accessKeySecret: process.env['TOS_SECRET_KEY'], region: "Provide your region", // 填写 Bucket 所在地域。以华北2(北京)为例,则 "Provide your region" 填写为 cn-beijing。 endpoint: "Provide your endpoint", // 填写域名地址 }); function handleError(error) { if (error instanceof TosClientError) { console.log('Client Err Msg:', error.message); console.log('Client Err Stack:', error.stack); } else if (error instanceof TosServerError) { console.log('Request ID:', error.requestId); console.log('Response Status Code:', error.statusCode); console.log('Response Header:', error.headers); console.log('Response Err Code:', error.code); console.log('Response Err Msg:', error.message); } else { console.log('unexpected exception, message: ', error); } } async function main() { try { const bucketName = 'node-sdk-test-bucket'; const objectName = 'example_dir/example.txt'; // 读取本地文件数据 const body = fs.createReadStream('./example.txt'); // 上传对象 await client.putObject({ bucket: bucketName, key: objectName, body, }); // 查询刚刚上传对象的大小 const { data } = await client.headObject({ bucket: bucketName, key: objectName, }); console.log('object size:', data['content-length']); } catch (error) { handleError(error); } } main();
您可以通过以下示例代码,使用 putObjectFromFile 接口,通过指定文件路径将文件上传到 TOS 指定 example_dir
目录下的 example.txt
文件。
// 导入 SDK, 当 TOS Node.JS SDK 版本小于 2.5.2 请把下方 TosClient 改成 TOS 导入 import { TosClient, TosClientError, TosServerError } from '@volcengine/tos-sdk'; import fs from 'fs'; // 创建客户端 const client = new TosClient({ accessKeyId: process.env['TOS_ACCESS_KEY'], accessKeySecret: process.env['TOS_SECRET_KEY'], region: "Provide your region", // 填写 Bucket 所在地域。以华北2(北京)为例,则 "Provide your region" 填写为 cn-beijing。 endpoint: "Provide your endpoint", // 填写域名地址 }); function handleError(error) { if (error instanceof TosClientError) { console.log('Client Err Msg:', error.message); console.log('Client Err Stack:', error.stack); } else if (error instanceof TosServerError) { console.log('Request ID:', error.requestId); console.log('Response Status Code:', error.statusCode); console.log('Response Header:', error.headers); console.log('Response Err Code:', error.code); console.log('Response Err Msg:', error.message); } else { console.log('unexpected exception, message: ', error); } } async function main() { try { const bucketName = 'node-sdk-test-bucket'; const objectName = 'example_dir/example.txt'; // 直接使用文件路径上传文件 await client.putObjectFromFile({ bucket: bucketName, key: objectName, filePath: './example.txt', }); // 查询刚刚上传对象的大小 const { data } = await client.headObject({ bucket: bucketName, key: objectName, }); console.log('object size:', data['content-length']); } catch (error) { handleError(error); } } main();
您可以通过以下示例代码,使用 putObject 接口,上传字符串数据到指定 example_dir
目录下的 example.txt
文件,上传时指定对象存储类型为低频存储,权限为私有同时设置上传文件元数据信息。
// 导入 SDK, 当 TOS Node.JS SDK 版本小于 2.5.2 请把下方 TosClient 改成 TOS 导入 import { ACLType, StorageClassType, TosClient, TosClientError, TosServerError } from '@volcengine/tos-sdk'; // 创建客户端 const client = new TosClient({ accessKeyId: process.env['TOS_ACCESS_KEY'], accessKeySecret: process.env['TOS_SECRET_KEY'], region: "Provide your region", // 填写 Bucket 所在地域。以华北2(北京)为例,则 "Provide your region" 填写为 cn-beijing。 endpoint: "Provide your endpoint", // 填写域名地址 }); function handleError(error) { if (error instanceof TosClientError) { console.log('Client Err Msg:', error.message); console.log('Client Err Stack:', error.stack); } else if (error instanceof TosServerError) { console.log('Request ID:', error.requestId); console.log('Response Status Code:', error.statusCode); console.log('Response Header:', error.headers); console.log('Response Err Code:', error.code); console.log('Response Err Msg:', error.message); } else { console.log('unexpected exception, message: ', error); } } async function main() { try { const bucketName = 'node-sdk-test-bucket'; const objectName = 'example_dir/example.txt'; // 上传对象 await client.putObject({ bucket: bucketName, key: objectName, // 将字符串 "Hello TOS" 上传到指定 example_dir 目录下的 example.txt body: Buffer.from('Hello TOS'), // 指定存储类型为低频存储 storageClass: StorageClassType.StorageClassIa, // 指定对象权限为私有 acl: ACLType.ACLPrivate, // 用户自定义元数据信息 meta: { key: 'value', }, }); // 查询刚刚上传的对象 const { data } = await client.headObject({ bucket: bucketName, key: objectName, }); console.log('object size:', data['content-length']); console.log('storage class:', data['x-tos-storage-class']); console.log('x-tos-meta-key:', data['x-tos-meta-key']); } catch (error) { handleError(error); } } main();
上传时可通过 dataTransferStatusChange
参数处理上传进度,代码示例如下。
// 导入 SDK, 当 TOS Node.JS SDK 版本小于 2.5.2 请把下方 TosClient 改成 TOS 导入 import { DataTransferType, TosClient, TosClientError, TosServerError } from '@volcengine/tos-sdk'; // 创建客户端 const client = new TosClient({ accessKeyId: process.env['TOS_ACCESS_KEY'], accessKeySecret: process.env['TOS_SECRET_KEY'], region: "Provide your region", // 填写 Bucket 所在地域。以华北2(北京)为例,则 "Provide your region" 填写为 cn-beijing。 endpoint: "Provide your endpoint", // 填写域名地址 }); function handleError(error) { if (error instanceof TosClientError) { console.log('Client Err Msg:', error.message); console.log('Client Err Stack:', error.stack); } else if (error instanceof TosServerError) { console.log('Request ID:', error.requestId); console.log('Response Status Code:', error.statusCode); console.log('Response Header:', error.headers); console.log('Response Err Code:', error.code); console.log('Response Err Msg:', error.message); } else { console.log('unexpected exception, message: ', error); } } async function main() { try { const bucketName = 'node-sdk-test-bucket'; const objectName = 'example_dir/example.txt'; // 上传对象 await client.putObject({ bucket: bucketName, key: objectName, // 将字符串 "Hello TOS" 上传到指定 example_dir 目录下的 example.txt body: Buffer.from('Hello TOS'), // 通过自定义方式设置回调函数查看上传进度 dataTransferStatusChange: (event) => { if (event.type === DataTransferType.Started) { console.log('Data Transfer Started'); } else if (event.type === DataTransferType.Rw) { const percent = ((event.consumedBytes / event.totalBytes) * 100).toFixed(2); console.log(`Once Read:${event.rwOnceBytes},ConsumerBytes/TotalBytes: ${event.consumedBytes}/${event.totalBytes},${percent}%`); } else if (event.type === DataTransferType.Succeed) { const percent = ((event.consumedBytes / event.totalBytes) * 100).toFixed(2); console.log(`Data Transfer Succeed, ConsumerBytes/TotalBytes:${event.consumedBytes}/${event.totalBytes},${percent}%`); } else if (event.type === DataTransferType.Failed) { console.log('Data Transfer Failed'); } }, }); // 查询刚刚上传的对象 const { data } = await client.headObject({ bucket: bucketName, key: objectName, }); console.log('object size:', data['content-length']); } catch (error) { handleError(error); } } main();
上传对象时可以通过客户端使用 rateLimiter
参数对上传数据所占用的带宽进行限制,代码如下所示。
// 导入 SDK, 当 TOS Node.JS SDK 版本小于 2.5.2 请把下方 TosClient 改成 TOS 导入 import { DataTransferType, TosClient, TosClientError, TosServerError, createDefaultRateLimiter } from '@volcengine/tos-sdk'; // 创建客户端 const client = new TosClient({ accessKeyId: process.env['TOS_ACCESS_KEY'], accessKeySecret: process.env['TOS_SECRET_KEY'], region: "Provide your region", // 填写 Bucket 所在地域。以华北2(北京)为例,则 "Provide your region" 填写为 cn-beijing。 endpoint: "Provide your endpoint", // 填写域名地址 }); function handleError(error) { if (error instanceof TosClientError) { console.log('Client Err Msg:', error.message); console.log('Client Err Stack:', error.stack); } else if (error instanceof TosServerError) { console.log('Request ID:', error.requestId); console.log('Response Status Code:', error.statusCode); console.log('Response Header:', error.headers); console.log('Response Err Code:', error.code); console.log('Response Err Msg:', error.message); } else { console.log('unexpected exception, message: ', error); } } async function main() { try { const bucketName = 'node-sdk-test-bucket'; const objectName = 'example_dir/example.txt'; const rateLimit1M = 1024 * 1024; // 上传对象 await client.putObject({ bucket: bucketName, key: objectName, // 将字符串 "Hello TOS" 上传到指定 example_dir 目录下的 example.txt body: Buffer.from('Hello TOS'), // 上传对象并在客户端限制上传速度为 1M/s rateLimiter: createDefaultRateLimiter(rateLimit1M, rateLimit1M), // 通过自定义方式设置回调函数查看上传进度 dataTransferStatusChange: (event) => { if (event.type === DataTransferType.Started) { console.log('Data Transfer Started'); } else if (event.type === DataTransferType.Rw) { const percent = ((event.consumedBytes / event.totalBytes) * 100).toFixed(2); console.log(`Once Read:${event.rwOnceBytes},ConsumerBytes/TotalBytes: ${event.consumedBytes}/${event.totalBytes},${percent}%`); } else if (event.type === DataTransferType.Succeed) { const percent = ((event.consumedBytes / event.totalBytes) * 100).toFixed(2); console.log(`Data Transfer Succeed, ConsumerBytes/TotalBytes:${event.consumedBytes}/${event.totalBytes},${percent}%`); } else if (event.type === DataTransferType.Failed) { console.log('Data Transfer Failed'); } }, }); // 查询刚刚上传的对象 const { data } = await client.headObject({ bucket: bucketName, key: objectName, }); console.log('object size:', data['content-length']); } catch (error) { handleError(error); } } main();
关于上传对象的 API 文档,请参见 PutObject。