AmazonS3提供了预签名URL以允许有授权的用户访问Bucket中的对象,该URL可以在一段时间内有效。然而,在Android平台下使用预签名URL仍然存在一些问题。
首先,由于Android平台下的HttpURLConnection具有连接复用机制,会导致同一连接上的请求出现头信息冲突的问题,因此需要手动断开连接,以便每次请求都能够带上正确的头信息。
其次,对于使用签名v4的Bucket,需要在请求头中添加Content-MD5字段以避免出现错误的签名,同时还需要在签名计算中考虑到该字段的影响。
最后,为了确保安全性,应该给预签名URL设置过期时间,以限制URL的有效时间。
以下代码示例展示了如何在Android平台下为AmazonS3预签名URL添加上述改进:
import java.io.IOException;
import java.io.InputStream;
import java.net.HttpURLConnection;
import java.net.URL;
import java.security.NoSuchAlgorithmException;
import java.time.LocalDateTime;
import java.time.ZoneOffset;
import java.time.format.DateTimeFormatter;
import java.util.Base64;
import java.util.Locale;
import javax.crypto.Mac;
import javax.crypto.spec.SecretKeySpec;
public class S3PresignedURL {
private static final String HMAC_SHA256_ALGORITHM = "HmacSHA256";
private static final String SIGNATURE_VERSION = "AWS4-HMAC-SHA256";
private static final String AWS_SECRET_ACCESS_KEY = "";
private static final String AWS_ACCESS_KEY_ID = "";
private static final String S3_BUCKET_NAME = "";
private static final String S3_OBJECT_KEY = "";
private static final int URL_EXPIRATION_SECONDS = 300;
public static String getPresignedURL() {
String url = null;
String amzDate = LocalDateTime.now(ZoneOffset.UTC).format(DateTimeFormatter.ofPattern("
上一篇:Android平台使用safeargs时无法解析java.time.LocalDate类型
下一篇:Android平台下出现异常“NoSuchAlgorithmException:SecretKeyFactorynotavailable”,如何解决?