aws-sdk-js-v3
You must generate an Access Key before getting started. All examples will utilize access_key_id and access_key_secret variables which represent the Access Key ID and Secret Access Key values you generated.
JavaScript または TypeScript のユーザーは、通常通り @aws-sdk/client-s3 ↗ npm パッケージを使用し続けることができます。S3 サービスクライアントをインスタンス化する際には、R2 設定の資格情報を渡す必要があります:
import { S3Client, ListBucketsCommand, ListObjectsV2Command, GetObjectCommand, PutObjectCommand,} from "@aws-sdk/client-s3";
const S3 = new S3Client({ region: "auto", endpoint: `https://${ACCOUNT_ID}.r2.cloudflarestorage.com`, credentials: { accessKeyId: ACCESS_KEY_ID, secretAccessKey: SECRET_ACCESS_KEY, },});
console.log(await S3.send(new ListBucketsCommand({})));// {// '$metadata': {// httpStatusCode: 200,// requestId: undefined,// extendedRequestId: undefined,// cfId: undefined,// attempts: 1,// totalRetryDelay: 0// },// Buckets: [// { Name: 'user-uploads', CreationDate: 2022-04-13T21:23:47.102Z },// { Name: 'my-bucket-name', CreationDate: 2022-05-07T02:46:49.218Z }// ],// Owner: {// DisplayName: '...',// ID: '...'// }// }
console.log( await S3.send(new ListObjectsV2Command({ Bucket: "my-bucket-name" })),);// {// '$metadata': {// httpStatusCode: 200,// requestId: undefined,// extendedRequestId: undefined,// cfId: undefined,// attempts: 1,// totalRetryDelay: 0// },// CommonPrefixes: undefined,// Contents: [// {// Key: 'cat.png',// LastModified: 2022-05-07T02:50:45.616Z,// ETag: '"c4da329b38467509049e615c11b0c48a"',// ChecksumAlgorithm: undefined,// Size: 751832,// StorageClass: 'STANDARD',// Owner: undefined// },// {// Key: 'todos.txt',// LastModified: 2022-05-07T21:37:17.150Z,// ETag: '"29d911f495d1ba7cb3a4d7d15e63236a"',// ChecksumAlgorithm: undefined,// Size: 279,// StorageClass: 'STANDARD',// Owner: undefined// }// ],// ContinuationToken: undefined,// Delimiter: undefined,// EncodingType: undefined,// IsTruncated: false,// KeyCount: 8,// MaxKeys: 1000,// Name: 'my-bucket-name',// NextContinuationToken: undefined,// Prefix: undefined,// StartAfter: undefined// }一時的にバケットへの公開読み取りまたは書き込みアクセスを共有するために使用できるプレサインされたリンクを生成することもできます。
import { getSignedUrl } from "@aws-sdk/s3-request-presigner";
// expiresIn プロパティを使用して、プレサインされたリンクが有効な期間を決定します。console.log( await getSignedUrl( S3, new GetObjectCommand({ Bucket: "my-bucket-name", Key: "dog.png" }), { expiresIn: 3600 }, ),);// https://my-bucket-name.<accountid>.r2.cloudflarestorage.com/dog.png?X-Amz-Algorithm=AWS4-HMAC-SHA256&X-Amz-Content-Sha256=UNSIGNED-PAYLOAD&X-Amz-Credential<credential>&X-Amz-Date=<timestamp>&X-Amz-Expires=3600&X-Amz-Signature=<signature>&X-Amz-SignedHeaders=host&x-id=GetObject
// putObject などの操作のためのリンクを作成して、特定のキーへの一時的な書き込みアクセスを許可することもできます。console.log( await getSignedUrl( S3, new PutObjectCommand({ Bucket: "my-bucket-name", Key: "dog.png" }), { expiresIn: 3600 }, ),);putObject の例で生成されたリンクを使用して、指定されたバケットとキーにアップロードすることができます。プレサインされたリンクが期限切れになるまで使用できます。
curl -X PUT https://my-bucket-name.<accountid>.r2.cloudflarestorage.com/dog.png?X-Amz-Algorithm=AWS4-HMAC-SHA256&X-Amz-Content-Sha256=UNSIGNED-PAYLOAD&X-Amz-Credential<credential>&X-Amz-Date=<timestamp>&X-Amz-Expires=3600&X-Amz-Signature=<signature>&X-Amz-SignedHeaders=host&x-id=PutObject -F "data=@dog.png"