Excon::Errors::Forbidden in UsersController#update



我正在尝试使用 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

我的用户控制器#更新是:

 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,也不明白我收到的任何错误消息。

有人有什么建议吗?

谢谢!

以防万一其他人遇到这个问题,这是我的解决方法:

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

因此,我授予了该用户高级用户和管理权限,并且我的头像正在正确加载!

Amazon AWS 管理控制台>> 用户>>选择 IAM 用户>>附加策略>> AmazonS3FullAccess

最新更新