WordPressブログのAmazonS3アカウントにアップロードされたACL:PRIVATEを含むビデオ/画像ファイルを表示する必要があります。
私はPHPoopsベースのコーディングの初心者です。スクリプトヘルプ、リンク参照、無料のプラグイン、さらには論理アルゴリズムも非常に役立ちます:)
前もって感謝します。
WordPressブログのAmazonS3アカウントにアップロードされたACL:PRIVATEを含むビデオ/画像ファイルを表示する必要があります。
私はPHPoopsベースのコーディングの初心者です。スクリプトヘルプ、リンク参照、無料のプラグイン、さらには論理アルゴリズムも非常に役立ちます:)
前もって感謝します。
この問題は、次の手順を実装することで解決できます。
wamp/www
フォルダに配置しますファイルの内容は次のようになります。
require('sdk.class.php');
require('services/s3.class.php');
$s3 = new AmazonS3();
$bucket = "bucketname";
$temp_link = $s3->get_object_url($bucket, 'your/folder/path/img.jpg', '5 minute');
echo $temp_link;
上記のコードでは、出力として受け取る URL はプライベート オブジェクトの署名付き URL であるため、5 分間しか有効ではありません。
将来の日付でアクセスを許可し、許可されたユーザーのみが Amazon S3 のプライベート コンテンツまたはメディアにアクセスできるようにすることができます。
この質問は少し古いですが、とにかく投稿しています。今日も同様の問題があり、簡単な答えがあることがわかりました。
aws doc はそれを明確に説明しており、例もあります。
http://docs.aws.amazon.com/aws-sdk-php-2/guide/latest/service-s3.html#amazon-s3-stream-wrapper
基本的に、AWS のストリームラッパーを登録し、s3:// プロトコルを使用する必要があります。
これが私のコードサンプルです。
use Aws\Common\Aws;
use Aws\S3\Enum\CannedAcl;
use Aws\S3\Exception\S3Exception;
$s3 = Aws::factory(array(
'key' => Config::get('aws.key'),
'secret' => Config::get('aws.secret'),
'region' => Config::get('aws.region')
))->get('s3');
$s3->registerStreamWrapper();
// now read file from s3
// from the doc.
// Open a stream in read-only mode
if ($stream = fopen('s3://bucket/key', 'r')) {
// While the stream is still open
while (!feof($stream)) {
// Read 1024 bytes from the stream
echo fread($stream, 1024);
}
// Be sure to close the stream resource when you're done with it
fclose($stream);
}