更新时间:2023-11-09 GMT+08:00

限定条件下载

开发过程中,您有任何问题可以在github上提交issue接口参考文档详细介绍了每个接口的参数和使用方法。

下载对象时,可以指定一个或多个限定条件,满足限定条件时则进行下载,否则抛出异常,下载对象失败。

您可以使用的限定条件如下:

参数

作用

OBS Android SDK对应方法

If-Modified-Since

如果对象的修改时间晚于该参数值指定的时间,则返回对象内容,否则抛出异常。

GetObjectRequest.setIfModifiedSince

If-Unmodified-Since

如果对象的修改时间早于该参数值指定的时间,则返回对象内容,否则抛出异常。

GetObjectRequest.setIfUnmodifiedSince

If-Match

如果对象的ETag值与该参数值相同,则返回对象内容,否则抛出异常。

GetObjectRequest.setIfMatchTag

If-None-Match

如果对象的ETag值与该参数值不相同,则返回对象内容,否则抛出异常。

GetObjectRequest.setIfNoneMatchTag

  • 对象的ETag值是指对象数据的MD5校验值。
  • 如果包含If-Unmodified-Since并且不符合或者包含If-Match并且不符合,抛出异常中HTTP状态码为:412 precondition failed。
  • 如果包含If-Modified-Since并且不符合或者包含If-None-Match并且不符合,抛出异常中HTTP状态码为:304 Not Modified。

以下代码展示了如何进行限定条件下载:

// 认证用的ak和sk硬编码到代码中或者明文存储都有很大的安全风险,建议在配置文件或者环境变量中密文存放,使用时解密,确保安全;本示例以ak和sk保存在环境变量中为例,运行本示例前请先在本地环境中设置环境变量ACCESS_KEY_ID和SECRET_ACCESS_KEY_ID。
// 您可以登录访问管理控制台获取访问密钥AK/SK,获取方式请参见https://support.huaweicloud.com/intl/zh-cn/usermanual-ca/ca_01_0003.html
String ak = System.getenv("ACCESS_KEY_ID");
String sk = System.getenv("SECRET_ACCESS_KEY_ID");
String endPoint = "https://your-endpoint";
// 创建ObsClient实例
final ObsClient obsClient = new ObsClient(ak, sk, endPoint);

GetObjectRequest request = new GetObjectRequest("bucketname", "objectname");
request.setRangeStart(0l);
request.setRangeEnd(1000l);

request.setIfModifiedSince(new SimpleDateFormat("yyyy-MM-dd").parse("2016-01-01"));
ObsObject obsObject = obsClient.getObject(request);

obsObject.getObjectContent().close();