2012-02-26 91 views
7

一直試圖尋找這個錯誤很長一段時間的原因,似乎無法找到任何...Carrierwave上傳與S3和霧

所以我有一個Rails應用程序,我使用的圖片carrierwave上傳。我也想在我的應用中使用Amazon S3進行文件上傳存儲。

最初爲我開發我允許上傳文件要上的應用:文件,即

image_uploader.rb

# Choose what kind of storage to use for this uploader: 
    storage :file 
# storage :fog 

現在在完成了開發,並把它活(我用heroku),我決定將carrierwave存儲改爲S3以在本地進行測試。

image_uploader.rb

# Choose what kind of storage to use for this uploader: 
# storage :file 
storage :fog 

不過,現在當我嘗試上傳圖片(可以是用戶的頭像等),我得到這個錯誤:

Excon::Errors::Forbidden in UsersController#update 
Expected(200) <=> Actual(403 Forbidden) 
request => {:connect_timeout=>60, :headers=>{"Content-Length"=>74577, "x-amz- acl"=>"private", "Content-Type"=>"image/png", "Date"=>"Sun, 26 Feb 2012 10:00:43 +0000", "Authorization"=>"AWS AKIAJOCDPFOU7UTT4HOQ:8ZnOy7X71nQAM87yraSI24Y5bSw=", "Host"=>"s3.amazonaws.com:443"}, :instrumentor_name=>"excon", :mock=>false, :read_timeout=>60, :retry_limit=>4, :ssl_verify_peer=>true, :write_timeout=>60, :host=>"s3.amazonaws.com", :path=>"/uploads//uploads%2Fuser%2Favatar%2F1%2Fjeffportraitmedium.png", :port=>"443", :query=>nil, :scheme=>"https", :body=>"\x89PNG\r\n\x1A\n\x00\x00\x00\rIHDR\x00\x00\x00\xC2\x00\x00\x00\xC3\b\x06\x00\x00\x00\xD0\xBD\xCE\x94\x00\x00\nCiCCPICC Profile\x00\x00x\x01\x9D\x96wTSY\x13\xC0\xEF{/\xBD\xD0\x12B\x91\x12z\rMJ\x00\x91\x12z\x91^E%$\ 
... 
# The code you see above to the far right repeats itself a LOT 
... 
[email protected]\x85\xB5\t\xFC_y~\xA6=:\xB2\xD0^\xBB~i\xBB\x82\x8F\x9B\xAF\xE7\x04m\xB2i\xFF\x17O\x94S\xF7l\x87\xA8&\x00\x00\x00\x00IEND\xAEB`\x82", :expects=>200, :idempotent=>true, :method=>"PUT"} 
response => #<Excon::Response:0x007fc88ca9f3d8 @body="<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<Error><Code>AccessDenied</Code><Message>Access Denied</Message><RequestId>8EFA56C0DDDC8878</RequestId><HostId>1OxWXppSSUq1MFjQwvnFptuCM3gKOuKdlQQyVSEgvzzv4Aj+r2hSFM2UUw2NYyrR</HostId></Error>", @headers={"x-amz-request-id"=>"8EFA56C0DDDC8878", "x-amz-id-2"=>"1OxWXppSSUq1MFjQwvnFptuCM3gKOuKdlQQyVSEgvzzv4Aj+r2hSFM2UUw2NYyrR", "Content-Type"=>"application/xml", "Transfer-Encoding"=>"chunked", "Date"=>"Sun, 26 Feb 2012 10:00:47 GMT", "Connection"=>"close", "Server"=>"AmazonS3"}, @status=403> 

,然後它說這個以及我的應用程序跟蹤:

app/controllers/users_controller.rb:39:in `update' 

,我有所求參數:

{"utf8"=>"✓", 
"_method"=>"put", 
"authenticity_token"=>"DvADD1vYpCLcghq+EIOwVSjsfmAWCHhtA3VI5VGD/q8=", 
"user"=>{"avatar"=>#<ActionDispatch::Http::UploadedFile:0x007fc88cde76f8  
@original_filename="JeffPortraitMedium.png", 
@content_type="image/png", 
@headers="Content-Disposition: form-data; name=\"user[avatar]\"; 
filename=\"JeffPortraitMedium.png\"\r\nContent-Type: image/png\r\n", 
@tempfile=#<File:/var/folders/vg/98nv58ss4v7gcbf8px_8dyqc0000gq/T/RackMultipart20120226- 19096-1ppu2sr>>, 
"remote_avatar_url"=>"", 
"name"=>"Jeff Lam ", 
"email"=>"[email protected]", 
"user_bio"=>"Tester Hello", 
"shop"=>"1"}, 
"commit"=>"Update Changes", 
"id"=>"1"} 

這裏是我的users_controller.rb部分代碼:

def update 
    @user = User.find(params[:id]) 
    if @user.update_attributes(params[:user]) 
     redirect_back_or root_path 
     flash[:success] = "Your have updated your settings successfully." 
    else 
     flash.now[:error] = "Sorry! We are unable to update your settings. Please check your fields and try again." 
     render 'edit' 
    end 
end 

我image_uploader.rb代碼

# encoding: utf-8 
class ImageUploader < CarrierWave::Uploader::Base 

    # Include RMagick or MiniMagick support: 
    # include CarrierWave::RMagick 
    include CarrierWave::MiniMagick 

    # Choose what kind of storage to use for this uploader: 
    # storage :file 
    storage :fog 

    # Override the directory where uploaded files will be stored. 
    # This is a sensible default for uploaders that are meant to be mounted: 
    def store_dir 
    "uploads/#{model.class.to_s.underscore}/#{mounted_as}/#{model.id}" 
    end 

    # Provide a default URL as a default if there hasn't been a file uploaded: 
    # def default_url 
    # "/images/fallback/" + [version_name, "default.png"].compact.join('_') 
    # end 

    # Process files as they are uploaded: 
    # process :scale => [200, 300] 
    # 
    # def scale(width, height) 
    # # do something 
    # end 

    # Create different versions of your uploaded files: 
    version :thumb do 
    process resize_to_fill: [360, 250] 
    end 

    version :cover_photo_thumb do 
    process resize_to_fill: [1170, 400] 
    end 

    version :event do 
    process resize_to_fill: [550, 382] 
    end 

    version :product do 
    process resize_to_fit: [226, 316] 
    end 

    # Add a white list of extensions which are allowed to be uploaded. 
    # For images you might use something like this: 
    def extension_white_list 
    %w(jpg jpeg gif png) 
    end 

    # Override the filename of the uploaded files: 
    # Avoid using model.id or version_name here, see uploader/store.rb for details. 
    # def filename 
    # "something.jpg" if original_filename 
    # end 

    # fix for Heroku, unfortunately, it disables caching, 
    # see: https://github.com/jnicklas/carrierwave/wiki/How-to%3A-Make-Carrierwave-work-on-Heroku 
    def cache_dir 
    "#{Rails.root}/tmp/uploads" 
    end 

end 

最後,在配置我fog.rb文件/初始化

CarrierWave.configure do |config| 
    config.fog_credentials = { 
    :provider    => 'AWS',  # required 
    :aws_access_key_id  => 'ACCESS_KEY',  # required 
    :aws_secret_access_key => 'SECRET_ACCESS_KEY/ZN5SkOUtOEHd61/Cglq9',  # required 
    :region     => 'Singapore' # optional, defaults to 'us-east-1' 
    } 
    config.fog_directory = 'ruuva/'      # required 
    config.fog_public  = false       # optional, defaults to true 
end 

我對fog.rb中的一些東西其實很困惑。首先,如果我在亞馬遜S3帳戶上創建了一個名爲「ruuva」的桶,並在該地區添加了「新加坡」,我應該將該地區更改爲新加坡嗎?

謝謝任何​​能夠提前幫助的人!

+3

不管它是什麼,如果你收到403這是一個認證錯誤。你需要首先在這個方向進行調查。 – three 2012-02-26 10:22:11

+0

嘗試在'ruuva'後刪除斜線,並將區域更改爲默認值。 – 2012-02-26 11:23:21

回答

8

首先確保你通過不設置自定義區域,並自定義目錄使用權證書(在默認區域免費創建一個假桶)

那麼我想你是不是該地區使用正確的名稱。嘗試設置你的區域是這樣的:

:region => 'ap-southeast-1' 
+2

謝謝!我做了你問我(檢查區域,做默認桶等),並以某種方式它的工作! 此外,如果有人以某種方式面臨同樣的問題:確保每次在fog.rb中更改某些內容時重新啓動開發應用程序服務器!新手錯誤,我知道。 :) – 2012-02-26 16:02:20

+0

S3不需要區域選擇。 – Rubyrider 2014-04-16 04:37:08

+0

它可能已經改變,但前一段時間S3有一個標準的端點,將您重定向到給定桶的適當區域。所以這並不理想,因爲每個請求都被重定向 – rpechayr 2014-04-16 09:27:58

5

我們面臨同樣的問題,修好了相關變更您訪問密鑰的用戶的許可,將其更改爲「高級用戶」。在投入生產之前,請檢查您是否需要用戶成爲超級用戶。

相關問題