本文介绍如何使用限定条件下载OSS文件。
下载文件时,可以指定一个或多个限定条件。满足限定条件则下载,不满足则返回错误,不下载。可以使用的限定条件如下:
参数 | 描述 |
---|---|
If-Modified-Since | 如果指定的时间早于实际修改时间,则正常传输文件,否则返回错误(304 Not modified)。 |
If-Unmodified-Since | 如果指定的时间等于或者晚于文件实际修改时间,则正常传输文件,否则返回错误(412 Precondition failed)。 |
If-Match | 如果指定的ETag和OSS文件的ETag匹配,则正常传输文件,否则返回错误(412 Precondition failed)。 |
If-None-Match | 如果指定的ETag和OSS文件的ETag不匹配,则正常传输文件,否则返回错误(304 Not modified)。 |
If-Modified-Since和If-Unmodified-Since可以同时存在。If-Match和If-None-Match可以同时存在。
ETag可以通过ossClient.getObjectMeta方法获取。
以下代码用于限定条件下载:
// Endpoint以杭州为例,其它Region请按实际情况填写。 String endpoint = "http://oss-cn-hangzhou.aliyuncs.com"; // 阿里云主账号AccessKey拥有所有API的访问权限,风险很高。强烈建议您创建并使用RAM账号进行API访问或日常运维,请登录 https://console.cloud.tmall.com 创建RAM账号。 String accessKeyId = "<yourAccessKeyId>"; String accessKeySecret = "<yourAccessKeySecret>"; String bucketName = "<yourBucketName>"; String objectName = "<yourObjectName>"; // 创建OSSClient实例。 OSS ossClient = new OSSClientBuilder().build(endpoint, accessKeyId, accessKeySecret); GetObjectRequest request = new GetObjectRequest(bucketName, objectName); // 设置限定条件。 request.setModifiedSinceConstraint(new Date()); // 下载OSS文件到本地文件。 ossClient.getObject(request, new File("<yourLocalFile>")); // 关闭OSSClient。 ossClient.shutdown();
ossClient.getObject和ossClient.downloadFile方法支持限定条件下载。