首页 文章

在AWS中调用PutObject操作时的InvalidRequest

提问于
浏览
0

我正在使用以下命令来验证我的用户是否可以访问S3存储桶:(基于此链接:http://docs.aws.amazon.com/AmazonS3/latest/dev/example-walkthroughs-managing-access-example1.html

$ aws s3api put-object --bucket bymspsbucket --key AWS.png --body Desktop/AWS.png --profile spsadmin

但我遇到了以下错误并坚持下去,不知道出了什么问题......

“调用PutObject操作时发生错误(InvalidRequest):缺少此请求所需的标头:x-amz-content-sha256”

我用--debug运行命令

请参阅以下链接中的debug-output文件:https://github.com/minafa/AWS/wiki

$ aws --version
aws-cli/1.10.59 Python/2.7.10 Darwin/15.0.0 botocore/1.4.49

我使用cmd:aws configure配置了配置文件,结果如下:

#vim ./aws/credentials
[default]
aws_access_key_id =
aws_secret_access_key =
[spsadmin]
aws_access_key_id =
aws_secret_access_key =

#vim ./aws/config

编辑:

由于凭证文件中没有区域,我手动修改了文件 . 所以它可以用于putobject,但是get对象给出了访问拒绝错误:

aws s3api get-object --bucket examplebucket --key AWS.png OutputFile.jpg --profile spsadmin

调用GetObject操作时发生错误(AccessDenied):拒绝访问

我在s3存储桶中设置的用户可以访问的权限如下:

"s3:GetBucketLocation",
"s3:ListBucket",
"s3:GetObject", 
"s3:PutObject"

是否需要在IAM我的用户帐户中附加相同的策略?在IAM的附加策略下,我只设置了“AmazonS3FullAccess”,但它不应该是FullAccess,因为用户必须只能访问我指定的存储桶 .

任何帮助,将不胜感激 .

1 回答

  • 0

    我已经解决了以下问题:

    • put-object无效,因为config / credentials文件中没有设置区域 . 所以.aws /凭证被修改了 .

    • get-object给出了Access denied错误,因为它需要设置:

    Bucket Policy中的“Action”:“s3:GetBucketAcl” .

相关问题