Excon :: Errors ::禁止在UsersController#update中

时间:2014-12-14 21:39:13

标签: amazon-s3 carrierwave

我尝试使用Carrierwave将图像上传到Amazon S3,以便为我的用户提供上传头像的机会。

当我添加图像文件并点击"更新时,"我收到以下错误消息:

Excon::Errors::Forbidden in UsersController#update
Expected(200) <=> Actual(403 Forbidden) excon.error.response :body => "<?xml version=\"1.0\"     encoding=\"UTF-8\"?>\n<Error><Code>AccessDenied</Code><Message>Access Denied</Message>    <RequestId>67D635476E2363B7</RequestId>    <HostId>Aw9W8C1ShJt73UGE6IuRZAOK6UkWM46hy+noygWCZAR2Has1lrCDpZkcgX2+7y7b</HostId></Error>" :headers     => { "Connection" => "close" "Content-Type" => "application/xml" "Date" => "Sun, 14 Dec 2014 21:21:35     GMT" "Server" => "AmazonS3" "x-amz-id-2" =>     "Aw9W8C1ShJt73UGE6IuRZAOK6UkWM46hy+noygWCZAR2Has1lrCDpZkcgX2+7y7b" "x-amz-request-id" =>     "67D635476E2363B7" } :local_address => "192.168.195.234" :local_port => 56281 :reason_phrase =>     "Forbidden" :remote_ip => "54.231.64.217" :status => 403

我的UsersController #Update是:

 def update
  if current_user.update_attributes(user_params)
  flash[:notice] = "User information updated"
  redirect_to edit_user_registration_path
 else
  flash[:notice] = "Invalid User information"
  redirect_to edit_user_registration_path
end
end

  private

   def user_params
     params.require(:user).permit(:name, :avatar)
   end

我更新头像的表格是:

    .form-group
      = f.label :name
      = f.text_field :name, class: 'form-control', placeholder: 'Enter name', autofocus: true
    - if current_user.avatar?
      .form-group
        %p Current avatar
        = image-tag(current_user.avatar.profile.url)
    .form-group
      = f.label :avatar
      = f.file_field :avatar 
      = f.hidden_field :avatar_cache 

    .form-group
      = f.submit 'Update', class: 'btn btn-success'

我在StackOverflow上发现了类似的问题,答案与为桶选择的区域有关;但S3不再需要区域了。 。

我对Excon不熟悉,而且我不理解我收到的任何错误消息。

有人有任何建议吗?

谢谢!

2 个答案:

答案 0 :(得分:2)

以防万一其他人遇到这个问题,以下是它对我的影响:

我在Amazon S3上使用IAM用户,而我用于此应用的访问权限和密钥没有权限的用户。哎呀。 。

所以,我给了该用户高级用户和管理权限,我的头像正在正确加载!

答案 1 :(得分:2)

亚马逊AWS管理控制台&gt;&gt;用户&gt;&gt;选择IAM用户&gt;&gt;附加政策&gt;&gt; AmazonS3FullAccess