Shrine と fineuploader を一緒に使用して、ファイルを S3 に直接アップロードしようとしています。
私が直面している問題は、Shrine gem の presign_endpoint が、次のような形式の json レスポンスを返す GET リクエストであることです。
{
"url": "https://my-bucket.s3-eu-west-1.amazonaws.com",
"fields": {
"key": "b7d575850ba61b44c8a9ff889dfdb14d88cdc25f8dd121004c8",
"policy": "eyJleHBpcmF0aW9uIjoiMjAxNS0QwMToxMToyOVoiLCJjb25kaXRpb25zIjpbeyJidWNrZXQiOiJzaHJpbmUtdGVzdGluZyJ9LHsia2V5IjoiYjdkNTc1ODUwYmE2MWI0NGU3Y2M4YTliZmY4OGU5ZGZkYjE2NTQ0ZDk4OGNkYzI1ZjhkZDEyMTAwNGM4In0seyJ4LWFtei1jcmVkZW50aWFsIjoiQUtJQUlKRjU1VE1aWlk0NVVUNlEvMjAxNTEwMjQvZXUtd2VzdC0xL3MzL2F3czRfcmVxdWVzdCJ9LHsieC1hbXotYWxnb3JpdGhtIjoiQVdTNC1ITUFDLVNIQTI1NiJ9LHsieC1hbXotZGF0ZSI6IjIwMTUxMDI0VDAwMTEyOVoifV19",
"x-amz-credential": "AKIAIJF55TMZYT6Q/20151024/eu-west-1/s3/aws4_request",
"x-amz-algorithm": "AWS4-HMAC-SHA256",
"x-amz-date": "20151024T001129Z",
"x-amz-signature": "c1eb634f83f96b69bd675f535b3ff15ae184b102fcba51e4db5f4959b4ae26f4"
},
"headers": {}
}
Fineuploader は、POST 要求を実行する署名エンドポイントを使用するため、「メソッドは許可されていません」というエラーが返されます。
var uploader = new qq.s3.FineUploader({
request: {
endpoint: '{ CDN_ENDPOINT_URL }'
accessKey: '{ ACCESS_KEY }'
},
objectProperties: {
bucket: '{ BUCKET_NAME }'
host: '{ BUCKET_HOST_NAME }'
},
signature: {
endpoint: '/presign'
}
});
fineuploader の署名メソッドを GET メソッドに変更する方法はありますか、それとも完全に間違った方向に進んでいますか? この機能を作成する際のアドバイスは大歓迎です。
https://github.com/gorails-screencasts/shrine-direct-upload-to-s3/blob/master/app/assets/javascripts/uploads.jsに似たようなことをしたいのですが、ファインアップローダーを使用します。