在AWS S3中进行服务器端加密需要使用AWS提供的服务端加密密钥(SSE-S3)或客户提供的加密密钥(SSE-C)。 在客户端提供的加密密钥(SSE-C)的情况下,必须在上传文件时提供密钥。以下是在Android中实现对S3服务器端加密上传文件的代码示例:
public class S3Encrypt { private final String S3_BUCKET_NAME = "bucketName"; private final String S3_REGION = "regionName"; // eg, us-west-2 private final String AWS_S3_ACCESS_KEY = "s3AccessKey"; private final String AWS_S3_SECRET_KEY = "s3SecretKey"; private final String ENCRYPTED_S3_OBJECT_KEY = "test-encrypted.txt"; private final String UNENCRYPTED_S3_OBJECT_KEY = "test-unencrypted.txt"; private final String SSE_C_ALGORITHM = "AES256"; private final String SSE_C_KEY = "my encryption key";
/**
* Upload an encrypted object to Amazon S3 using SSE-C.
*/
public void uploadEncryptedS3Object() {
try {
// Create a new S3 client and set the region.
AmazonS3 s3client = new AmazonS3Client(new BasicAWSCredentials(AWS_S3_ACCESS_KEY, AWS_S3_SECRET_KEY));
s3client.setRegion(RegionUtils.getRegion(S3_REGION));
// Create metadata for an encrypted S3 object.
ObjectMetadata metadata = new ObjectMetadata();
metadata.setSSEAlgorithm(SSEAlgorithm.KMS.getAlgorithm());
// Provide an input stream for the object to upload.
InputStream plaintextStream = new ByteArrayInputStream("Hello, Amazon S3!".getBytes());
// Generate an encryption key.
byte[] key = SSECustomerKey.generateSymmetricKey();
// Encrypt the object and upload it to S3.
PutObjectRequest putRequest = new PutObjectRequest(S3_BUCKET_NAME, ENCRYPTED_S3_OBJECT_KEY, plaintextStream, metadata)
.withSSECustomerKey(new SSECustomerKey(key))