public class AccessControlList extends Object implements Serializable
Represents an Amazon S3 Access Control List (ACL), including the ACL's set of grantees and the permissions assigned to each grantee.
Each bucket and object in Amazon S3 has an ACL that defines its access control policy. When a request is made, Amazon S3 authenticates the request using its standard authentication procedure and then checks the ACL to verify the sender was granted access to the bucket or object. If the sender is approved, the request proceeds. Otherwise, Amazon S3 returns an error.
An ACL contains a list of grants. Each grant consists of one grantee and one permission. ACLs only grant permissions; they do not deny them.
For convenience, some commonly used ACLs are defined in
CannedAccessControlList
.
Note: Bucket and object ACLs are completely independent; an object does not inherit an ACL from its bucket. For example, if you create a bucket and grant write access to another user, you will not be able to access the user's objects unless the user explicitly grants access. This also applies if you grant anonymous write access to a bucket. Only the user "anonymous" will be able to access objects the user created unless permission is explicitly granted to the bucket owner.
Important: Do not grant the anonymous group
write access to buckets, as you will have no control over the objects
others can store and their associated charges. For more information, see
Grantee
and Permissions
.
CannedAccessControlList
,
序列化表格构造器和说明 |
---|
AccessControlList() |
AccessControlList(Map<String,Object> jsonMap)
Create AccessControlList from json map
|
限定符和类型 | 方法和说明 |
---|---|
Set<Grant> |
getGrants()
Gets the set of
Grant objects in this access control list (ACL). |
void |
grantAllPermissions(Grant... grantsVarArg)
Adds a set of grantee/permission pairs to the access control list (ACL), where each item in the
set is a
Grant object. |
void |
grantPermission(Grantee grantee,
HashSet<Permission> permissions) |
void |
grantPermission(Grantee grantee,
Permission permission)
Adds a grantee to the access control list (ACL) with the given permission.
|
void |
grantPermissions(Grantee grantee,
Permission... permissions) |
void |
revokeAllPermissions(Grantee grantee)
Revokes the permissions of a grantee by removing the grantee from the access control list (ACL).
|
String |
toString() |
public void grantPermission(Grantee grantee, Permission permission)
grantee
- The grantee to whom the permission will apply.permission
- The permission to apply to the grantee.public void grantPermissions(Grantee grantee, Permission... permissions)
public void grantPermission(Grantee grantee, HashSet<Permission> permissions)
public void grantAllPermissions(Grant... grantsVarArg)
Grant
object.grants
- A collection of Grant
objectspublic void revokeAllPermissions(Grantee grantee)
grantee
- The grantee to remove from this ACL.public Set<Grant> getGrants()
Grant
objects in this access control list (ACL).Grant
objects in this ACL.Copyright © 2016. All rights reserved.