コンテンツにスキップ

aws4fetch

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のユーザーは、通常通りaws4fetch npmパッケージを使用し続けることができます。このパッケージは、ブラウザやCloudflare Workersで作業する際に馴染みのあるfetchおよびSubtleCrypto APIを使用しています。

S3サービスクライアントをインスタンス化する際には、R2の設定資格情報を渡す必要があります:

import { AwsClient } from "aws4fetch";
const R2_URL = `https://${ACCOUNT_ID}.r2.cloudflarestorage.com`;
const client = new AwsClient({
accessKeyId: ACCESS_KEY_ID,
secretAccessKey: SECRET_ACCESS_KEY,
});
const ListBucketsResult = await client.fetch(R2_URL);
console.log(await ListBucketsResult.text());
// <ListAllMyBucketsResult>
// <Buckets>
// <Bucket>
// <CreationDate>2022-04-13T21:23:47.102Z</CreationDate>
// <Name>user-uploads</Name>
// </Bucket>
// <Bucket>
// <CreationDate>2022-05-07T02:46:49.218Z</CreationDate>
// <Name>my-bucket-name</Name>
// </Bucket>
// </Buckets>
// <Owner>
// <DisplayName>...</DisplayName>
// <ID>...</ID>
// </Owner>
// </ListAllMyBucketsResult>
const ListObjectsV2Result = await client.fetch(
`${R2_URL}/my-bucket-name?list-type=2`,
);
console.log(await ListObjectsV2Result.text());
// <ListBucketResult>
// <Name>my-bucket-name</Name>
// <Contents>
// <Key>cat.png</Key>
// <Size>751832</Size>
// <LastModified>2022-05-07T02:50:45.616Z</LastModified>
// <ETag>"c4da329b38467509049e615c11b0c48a"</ETag>
// <StorageClass>STANDARD</StorageClass>
// </Contents>
// <Contents>
// <Key>todos.txt</Key>
// <Size>278</Size>
// <LastModified> 2022-05-07T21:37:17.150Z</LastModified>
// <ETag>"29d911f495d1ba7cb3a4d7d15e63236a"</ETag>
// <StorageClass>STANDARD</StorageClass>
// </Contents>
// <IsTruncated>false</IsTruncated>
// <MaxKeys>1000</MaxKeys>
// <KeyCount>2</KeyCount>
// </ListBucketResult>

プレサインされたURLの生成

プレサインされたリンクを生成して、一時的にバケットへの公開読み取りまたは書き込みアクセスを共有することもできます。

import { AwsClient } from "aws4fetch";
const client = new AwsClient({
service: "s3",
region: "auto",
accessKeyId: ACCESS_KEY_ID,
secretAccessKey: SECRET_ACCESS_KEY,
});
const R2_URL = `https://${ACCOUNT_ID}.r2.cloudflarestorage.com`;
// `X-Amz-Expires`クエリパラメータを使用して、プレサインされたリンクが有効な期間を決定します。
console.log(
(
await client.sign(
new Request(`${R2_URL}/my-bucket-name/dog.png?X-Amz-Expires=${3600}`),
{
aws: { signQuery: true },
},
)
).url.toString(),
);
// https://<accountid>.r2.cloudflarestorage.com/my-bucket-name/dog.png?X-Amz-Expires=3600&X-Amz-Date=<timestamp>&X-Amz-Algorithm=AWS4-HMAC-SHA256&X-Amz-Credential=<credential>&X-Amz-SignedHeaders=host&X-Amz-Signature=<signature>
// PutObjectなどの操作のためのリンクを作成して、特定のキーへの一時的な書き込みアクセスを許可することもできます。
console.log(
(
await client.sign(
new Request(`${R2_URL}/my-bucket-name/dog.png?X-Amz-Expires=${3600}`, {
method: "PUT",
}),
{
aws: { signQuery: true },
},
)
).url.toString(),
);

PutObjectの例で生成されたリンクを使用して、プレサインされたリンクが期限切れになるまで、指定されたバケットとキーにアップロードできます。

Terminal window
curl -X PUT "https://<accountid>.r2.cloudflarestorage.com/my-bucket-name/dog.png?X-Amz-Expires=3600&X-Amz-Date=<timestamp>&X-Amz-Algorithm=AWS4-HMAC-SHA256&X-Amz-Credential=<credential>&X-Amz-SignedHeaders=host&X-Amz-Signature=<signature>" -F "data=@dog.png"