3

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に似たようなことをしたいのですが、ファインアップローダーを使用します。

4

0 に答える 0