9
12

More than 5 years have passed since last update.

AWS S3のファイルを署名付きURLでアクセスする

Posted at

EC2からS3にアクセスしてオブジェクトを返却してbase64でエンコードして・・なんて
実装も手間だし(多少処理時間も短縮したいし)なので、
private設定のままクライアント側から直接S3を参照できないものかと実験しました

環境

  • php 7.2
  • laravel 5.5
  • Vagrant 2.0.2
  • VirtualBox 5.2.6

準備

AWSコンソールのIAMでS3の権限をもつユーザを作成(readだけで良いはず)
S3はprivateにしておく(デフォルト)

手順

aws-sdk-phpを使います

◆SDKインストール

コンソール
php composer.phar require aws/aws-sdk-php

◆Controller

※認証情報は仮で直書きですが.envかconfigにもちましょう!

Controller
//認証情報
$s3 = new Aws\S3\S3Client([
    'credentials' => [
        'key'    => 'XXXXXXXXXXX', //アクセスキー
        'secret' => 'SSSSSSSSSSSSSSSSSSSSSSSSS', //シークレットキー
    ],
    'version' => 'latest',
    'region'  => 'us-east-1' //リージョン
]);

$command = $s3->getCommand('GetObject', array(
    'Bucket' => 'bucketName', //bucket
    'Key' => 'work/test.png', //bucket名以下のファイルパス
));

$request = $s3->createPresignedRequest($command, '+1 minutes'); //有効期限 ※左記は1分で設定

//URL取得
$request->getUri();

こんな感じのURLが返却されます

URL
https://s3.amazonaws.com/bucketName/work/test.png?X-Amz-Content-Sha256=UNSIGNED-PAYLOAD&X-Amz-Algorithm=AWS4-HMAC-SHA256&X-Amz-Credential=XXXXXXXXXXX%2F20190110%2Fus-east-1%2Fs3%2Faws4_request&X-Amz-Date=20190110T002959Z&X-Amz-SignedHeaders=host&X-Amz-Expires=60&X-Amz-Signature=3eb4e9937a3bcb42bc48b57694545484842a2645356949b438737aa965d2

これをviewに渡してあげて、imgタグに埋め込むと表示できます!
有効期限1分だけアクセスできるので、ロード後(厳密には1分後)には無効なURLになります!

まだまだ勉強中なので、もし間違っていたらご指摘いただけますと幸いです。(´;ω;`)

9
12
1

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
9
12