删除桶策略
Bucket是用于存储对象(Object)的容器,所有的对象都必须隶属于某个Bucket。本文介绍如何删除桶(Bucket)策略。
- DeleteBucketPolicy
DeleteBucketPolicy操作可以删除桶已经配置的策略,桶的创建者默认拥有删除桶策略的权限。
代码示例:
// 删除桶策略
func DeleteBucketPolicy(svc *s3.S3) {
deleteBucketPolicyInput := &s3.DeleteBucketPolicyInput{
Bucket: aws.String("exampleBucket"),
}
_, err := svc.DeleteBucketPolicy(deleteBucketPolicyInput)
if err != nil {
fmt.Printf("fail to delete bucket policy. %v\n", err)
return
}
}
DeleteBucketPolicyInput可以设置的参数如下:
参数 | 类型 | 说明 | 是否必要 |
---|---|---|---|
Bucket | *string | 桶的名称。 | 是 |
- DeleteBucketPolicyRequest
DeleteBucketPolicyRequest操作首先生成一个"request.Request"对象,该对象是一个执行DeleteBucketPolicy操作的请求。通过调用Request对象的Send方法完成删除桶策略的操作。该方法可以生成定制化的请求,例如自定义请求头部请求超时重试设置。
代码示例:
func DeleteBucketPolicyRequest(svc *s3.S3) {
deleteBucketPolicyInput := &s3.DeleteBucketPolicyInput{
Bucket: aws.String("exampleBucket"),
}
req, resp := svc.DeleteBucketPolicyRequest(deleteBucketPolicyInput)
err := req.Send()
if err != nil {
fmt.Printf("fail to delete bucket policy. %v\n", err)
} else {
fmt.Println(resp)
}
}
响应结果:
HTTP状态 | 响应码 | 描述 |
---|---|---|
200 | Success | 操作成功。 |
403 | AccessDenied | 用户没有权限执行操作。 |
404 | NoSuchKey | 操作指定的桶不存在。 |