【仓颉三方库】对象存储——OBS Cangjie SDK

介绍

对象存储服务软件开发工具包(OBS SDK,Object Storage Service Software Development Kit)是对OBS服务提供的REST API进行的封装,以简化用户的开发工作。用户直接调用OBS SDK提供的接口函数即可实现使用OBS服务业务能力的目的。

特性

  • 🚀 服务端加密,支持SSE-OBS,SM4服务端加密方式
  • 🚀 生命周期管理
  • 🚀 图片处理特性
  • 🚀 并行文件系统的权限配置
  • 🚀 在线解压
  • 🚀 桶策略列表呈现方式优化
  • 🚀 CDN自动刷新
  • 🚀 支持镜像回源
  • 🚀 持为对象设置WORM策略

产品架构

OBS的基本组成是桶和对象。

桶是OBS中存储对象的容器,每个桶都有自己的存储类别、访问权限、所属区域等属性,用户在互联网上通过桶的访问域名来定位桶。

对象是OBS中数据存储的基本单位,一个对象实际是一个文件的数据与其相关属性信息的集合体,包括Key、Metadata、Data三部分:

  • Key:键值,即对象的名称,为经过UTF-8编码的长度大于0且不超过1024的字符序列。一个桶里的每个对象必须拥有唯一的对象键值。
  • Metadata:元数据,即对象的描述信息,包括系统元数据和用户元数据,这些元数据以键值对(Key-Value)的形式被上传到OBS中。
    • 系统元数据由OBS自动产生,在处理对象数据时使用,包括Date,Content-length,Last-modify,ETag等。
    • 用户元数据由用户在上传对象时指定,是用户自定义的对象描述信息。
  • Data:数据,即文件的数据内容。

华为云针对OBS提供的REST API进行了二次开发,为您提供了控制台、SDK和各类工具,方便您在不同的场景下轻松访问OBS桶以及桶中的对象。当然您也可以利用OBS提供的SDK和API,根据您业务的实际情况自行开发,以满足不同场景的海量数据存储诉求。

源码目录

cj 复制代码
├─ lib
│  ├─ crypto4cj
│  ├─ httpclient4cj
│  └─ libcrypto.dll
└─ src
   ├─ logger
   ├─ obstest
   ├─ services
   │  ├─ action
   │  ├─ client
   │  ├─ crypto
   │  ├─ exception
   │  ├─ model
   │  ├─ progress
   │  ├─ requestHandler
   │  ├─ responseHandler
   └─ util
  • lib 第三方依赖
  • src 源码目录
  • src/log 日志记录类
  • src/obstest 测试用例
  • src/services/action 业务处理
  • src/services/client 请求入口
  • src/services/crypto 加密处理
  • src/services/exception 异常处理
  • src/services/model 模块类
  • src/services/progress传输进度处理
  • src/services/requestHandler请求前处理
  • src/services/responseHandler请求后处理
  • src/util 工具类

接口说明

使用说明

依赖分析

cj 复制代码
cnagjie:  v0.51.4
obsserver: v3.23.9

编译(win/linux)

cj 复制代码
cjpm build -V

功能示例

示例详见demo

创建 桶

cj 复制代码
main(): Int64 {

    // endpoint填写桶所在的endpoint
    var endPoint = "https://obs.cn-east-3.myhuaweicloud.com"
    // 您可以登录访问管理控制台获取访问密钥AK/SK
    var ak = "xxxxxxxxx"
    var sk = "xxxxxxxxxxxxx"
    // 创建ObsClient实例
    var obsClient = ObsClient().creatObsClient(ak, sk, endPoint)
    var createBucketRequest = CreateBucketRequest("cn-east-3", "cangjietest4")
    //设置桶访问权限
    createBucketRequest.setAcl(AccessControlList.REST_CANNED_PUBLIC_READ)
    //设置桶存储类型
    createBucketRequest.setStorageClass(StorageClassEnum.COLD)
    //创建桶
    var obsbucket = obsClient.createBucket(createBucketRequest)
}

设置对象元数据

cj 复制代码
main(): Int64 {

    // endpoint填写桶所在的endpoint
    var endPoint = "https://obs.cn-east-3.myhuaweicloud.com"
    // 您可以登录访问管理控制台获取访问密钥AK/SK
    var ak = "xxxxxxxxx"
    var sk = "xxxxxxxxxxxxx"
    // 创建ObsClient实例
    var obsClient = ObsClient().creatObsClient(ak, sk, endPoint)
    var request = SetObjectMetadataRequest("cangjie12", "testkey")
    request.setExpires("Expires")
    //设置对象自定义元数据
    request.addUserMetadata("property1", "property-value1")
    //用户头域列表
    var userHeaders = HashMap<String, String>()
    userHeaders.put("property2", "property-value2")
    userHeaders.put("x-obs-meta-property3", "property-value3")
    request.setUserHeaders(userHeaders)
    var metadata = obsClient.setObjectMetadataImpl(request)
    var  mate =  metadata.getUserMetadata("property1").getOrThrow()
    println((mate as String).getOrThrow())
}

DD一下: 欢迎大家关注公众号<程序猿百晓生>,可以了解到以下知识点。

erlang 复制代码
`欢迎大家关注公众号<程序猿百晓生>,可以了解到以下知识点。`
1.OpenHarmony开发基础
2.OpenHarmony北向开发环境搭建
3.鸿蒙南向开发环境的搭建
4.鸿蒙生态应用开发白皮书V2.0 & V3.0
5.鸿蒙开发面试真题(含参考答案) 
6.TypeScript入门学习手册
7.OpenHarmony 经典面试题(含参考答案)
8.OpenHarmony设备开发入门【最新版】
9.沉浸式剖析OpenHarmony源代码
10.系统定制指南
11.【OpenHarmony】Uboot 驱动加载流程
12.OpenHarmony构建系统--GN与子系统、部件、模块详解
13.ohos开机init启动流程
14.鸿蒙版性能优化指南
.......

对象上传

cj 复制代码
main(): Int64 {

    // endpoint填写桶所在的endpoint
    var endPoint = "https://obs.cn-east-3.myhuaweicloud.com"
    // 您可以登录访问管理控制台获取访问密钥AK/SK
    var ak = "xxxxxxxxx"
    var sk = "xxxxxxxxxxxxx"
    // 创建ObsClient实例
    var obsClient = ObsClient().creatObsClient(ak, sk, endPoint)
    var createBucketRequest = CreateBucketRequest("cangjie4")
    var putObjectRequest = PutObjectRequest()
    var str = "hello world"
    var byteStream = ByteArrayStream()
    byteStream.write(str.toArray())
    //流上传
    putObjectRequest.setInput(byteStream)
    putObjectRequest.setBucketName("cangjie4")
    putObjectRequest.setObjectKey("hello11")
    var obsfile = obsClient.putObject(putObjectRequest)
    println(obsfile.getObjectUrl())
}

范围下载

cj 复制代码
main(): Int64 {

    // endpoint填写桶所在的endpoint
    var endPoint = "https://obs.cn-east-3.myhuaweicloud.com"
    // 您可以登录访问管理控制台获取访问密钥AK/SK
    var ak = "xxxxxxxxx"
    var sk = "xxxxxxxxxxxxx"
    // 创建ObsClient实例
    var obsClient = ObsClient().creatObsClient(ak, sk, endPoint)
    var getObjectRequest = GetObjectRequest()
    //设置范围
    getObjectRequest.rangeStart = 0
    getObjectRequest.rangeEnd = 10
    getObjectRequest.setBucketName("cangjie12")
    getObjectRequest.setObjectKey("Obstestkey1")
    var obsobject = obsClient.getObject(getObjectRequest)
    var input = obsobject.getInputStream().getOrThrow()
    let output = ByteArrayStream()
    IOUtils.copyToStream(input, output)
    println(output.bytes().toString())
    println(String.fromUtf8(output.bytes())) 
}

欢迎给我们提交PR & Issue,欢迎参与任何形式的贡献。

相关推荐
星释4 小时前
鸿蒙Flutter仓库停止更新?
flutter·华为·harmonyos
云_杰4 小时前
鸿蒙开发干货——手把手教你玩转多媒体文件操作
harmonyos·交互设计
王老汉4 小时前
鸿蒙生态新利器:华为ArkUI-X混合开发框架深度解析
华为·harmonyos·arkui-x
NapleC6 小时前
HarmonyOS:网络HTTP数据请求
网络·http·harmonyos
新小梦9 小时前
OpenHarmony声明为系统应用和系统签名文件
harmonyos
别说我什么都不会10 小时前
【仓颉三方库】 数据解析——ini4cj
harmonyos
悬空八只脚10 小时前
React-Native开发鸿蒙NEXT-svg绘制睡眠质量图part1
harmonyos
搞瓶可乐1 天前
鸿蒙ArkUI实战之组件;Text组件,Image组件,Button组件,Span组件和TextInput组件的使用场景及使用方法
华为·harmonyos·鸿蒙系统·arkui·组件化开发·基础组件使用
九丘教育1 天前
【仓颉 + 鸿蒙 + AI Agent】CangjieMagic框架(15):NaiveExecutor
人工智能·华为·harmonyos