详情页标题前

腾讯云对象存储快速入门

详情页1

相关资源

SDK 源码下载示例 DemoSDK 更新日志Pub 地址

准备工作

1. 您需要一个纯 Flutter 项目或 Flutter 原生混合项目,这个应用可以是您现有的工程,也可以是您新建的一个空的工程。2. Flutter 版本要求:

  sdk: ">=2.15.0 <4.0.0"  flutter: ">=2.5.0"

第一步:SDK 介绍

tencentcloud_cos_sdk_plugin 目前兼容支持 iOS、Android,是通过 Flutter Plugin 桥接原生 AndroidiOS 的 COS SDK 实现。

第二步:集成 SDK

1. 运行此命令:

flutter pub add tencentcloud_cos_sdk_plugin

2. 这将向您的包的 pubspec.yaml 添加这样一行(并运行隐式 flutter pub get)

dependencies:  tencentcloud_cos_sdk_plugin: ^1.0.9

3. 在您的 Dart 代码中,您可以使用 import 进行导入,然后开始使用:

import 'package:tencentcloud_cos_sdk_plugin/cos.dart';

第三步:开始使用

注意建议用户 使用临时密钥 调用 SDK,通过临时授权的方式进一步提高 SDK 使用的安全性。申请临时密钥时,请遵循 最小权限指引原则,防止泄露目标存储桶或对象之外的资源。如果您一定要使用永久密钥,建议遵循 最小权限指引原则 对永久密钥的权限范围进行限制。

1. 初始化密钥

实现获取临时密钥

实现一个 IFetchCredentials 的类,实现请求临时密钥并返回结果的过程。

import 'dart:convert';import 'dart:io';
import 'package:flutter/foundation.dart';import 'package:tencentcloud_cos_sdk_plugin/fetch_credentials.dart';import 'package:tencentcloud_cos_sdk_plugin/pigeon.dart';
class FetchCredentials implements IFetchCredentials{ @override Future fetchSessionCredentials() async { // 首先从您的临时密钥服务器获取包含了密钥信息的响应,例如: var httpClient = HttpClient(); try { // 临时密钥服务器 url,临时密钥生成服务请参考 https://cloud.tencent.com/document/product/436/14048 var stsUrl = "http://stsservice.com/sts"; var request = await httpClient.getUrl(Uri.parse(stsUrl)); var response = await request.close(); if (response.statusCode == HttpStatus.OK) { var json = await response.transform(utf8.decoder).join(); print(json);
// 然后解析响应,获取临时密钥信息 var data = jsonDecode(json); // 最后返回临时密钥信息对象 return SessionQCloudCredentials( secretId: data['credentials']['tmpSecretId'],// 临时密钥 SecretId secretKey: data['credentials']['tmpSecretKey'],// 临时密钥 SecretKey token: data['credentials']['sessionToken'],// 临时密钥 Token startTime: data['startTime'],//临时密钥有效起始时间,单位是秒 expiredTime: data['expiredTime']//临时密钥有效截止时间戳,单位是秒 ); } else { throw ArgumentError(); } } catch (exception) { throw ArgumentError(); } }}

这里假设类名为 FetchCredentials。初始化一个实例,来给 SDK 提供密钥。

Cos().initWithSessionCredential(FetchCredentials());

实现获取限制范围的临时密钥

该方式可以更精细的控制临时密钥的使用范围,STSCredentialScope中包含了本次请求的action(操作)、region(地域)、bucket(桶名)、prefix(资源路径),
使用STSCredentialScope可以生成一个限定范围的临时密钥,例如根据prefix生成固定路径文件名的上传临时密钥,实现每个上传文件都有单独的临时密钥。
实现一个 IFetchScopeLimitCredentials 的类,实现请求限制范围的临时密钥并返回结果的过程。

import 'dart:convert';import 'dart:io';
import 'package:flutter/foundation.dart';import 'package:tencentcloud_cos_sdk_plugin/fetch_credentials.dart';import 'package:tencentcloud_cos_sdk_plugin/pigeon.dart';
class FetchScopeLimitCredentials implements IFetchScopeLimitCredentials{ @override Future fetchScopeLimitCredentials(List stsCredentialScopes) async { // 首先从您的临时密钥服务器获取包含了密钥信息的响应,例如: var httpClient = HttpClient(); try { // 临时密钥服务器 url,临时密钥生成服务请参考 https://cloud.tencent.com/document/product/436/14048 // 范围限制的临时密钥服务请参考:https://cloud.tencent.com/document/product/436/31923 var stsUrl = "https://stsservice.com/sts/scope"; var request = await httpClient.postUrl(Uri.parse(stsUrl)); request.headers.contentType = ContentType.json; // 将范围实体列表转换为post body中的json final body = jsonifyScopes(stsCredentialScopes); if (kDebugMode) { print(body); } request.write(body);
var response = await request.close(); if (response.statusCode == HttpStatus.OK) { var json = await response.transform(utf8.decoder).join(); if (kDebugMode) { print(json); } // 然后解析响应,获取临时密钥信息 var data = jsonDecode(json); // 最后返回临时密钥信息对象 return SessionQCloudCredentials( secretId: data['credentials']['tmpSecretId'], secretKey: data['credentials']['tmpSecretKey'], token: data['credentials']['sessionToken'], startTime: data['startTime'], expiredTime: data['expiredTime'] ); } else { throw ArgumentError(); } } catch (exception) { if (kDebugMode) { print(exception); } throw ArgumentError(); } }
// 将范围实体列表转换为json String jsonifyScopes(List scopes) { List<Map> scopeList = []; for (STSCredentialScope? scope in scopes) { if(scope != null) { Map scopeMap = { 'action': scope.action, 'bucket': scope.bucket, 'prefix': scope.prefix, 'region': scope.region, }; scopeList.add(scopeMap); } } return jsonEncode(scopeList); }}

这里假设类名为 FetchScopeLimitCredentials。初始化一个实例,来给 SDK 提供密钥。

Cos().initWithScopeLimitCredential(FetchScopeLimitCredentials());

强制使本地保存的临时密钥失效

该功能可以强制使 COS SDK 已经缓存的临时密钥失效,包括无限制使用范围和限制使用范围的临时密钥,失效后再使用 COS 接口功能时 SDK 会重新向业务临时密钥服务端获取新的临时密钥。
调用方法:

await Cos().forceInvalidationCredential();

使用永久密钥进行本地调试

您可以使用腾讯云的永久密钥来进行开发阶段的本地调试。由于该方式存在泄露密钥的风险,请务必在上线前替换为临时密钥的方式。

String SECRET_ID = "SECRETID"; //永久密钥 secretIdString SECRET_KEY = "SECRETKEY"; //永久密钥 secretKey
Cos().initWithPlainSecret(SECRET_ID, SECRET_KEY);

2. 注册 COS 服务

// 存储桶所在地域简称,例如广州地区是 ap-guangzhouString region = "COS_REGION";// 创建 CosXmlServiceConfig 对象,根据需要修改默认的配置参数CosXmlServiceConfig serviceConfig = CosXmlServiceConfig(    region: region,    isDebuggable: true,    isHttps: true,);// 注册默认 COS ServiceCos().registerDefaultService(serviceConfig);
// 创建 TransferConfig 对象,根据需要修改默认的配置参数// TransferConfig 可以设置智能分块阈值 默认对大于或等于2M的文件自动进行分块上传,可以通过如下代码修改分块阈值TransferConfig transferConfig = TransferConfig( forceSimpleUpload: false, enableVerification: true, divisionForUpload: 2097152, // 设置大于等于 2M 的文件进行分块上传 sliceSizeForUpload: 1048576, //设置默认分块大小为 1M);// 注册默认 COS TransferMangerCos().registerDefaultTransferManger(serviceConfig, transferConfig);
// 也可以通过 registerService 和 registerTransferManger 注册其他实例, 用于后续调用// 一般用 region 作为注册的 keyString newRegion = "NEW_COS_REGION";Cos().registerService(newRegion, serviceConfig..region = newRegion);Cos().registerTransferManger(newRegion, serviceConfig..region = newRegion, transferConfig);

参数说明

CosXmlServiceConfig 用于配置 COS 服务,其主要成员说明如下:

参数名称 描述 类型 默认值 支持平台 必选
region 存储桶地域 地域和访问域名 String null Android和iOS
isDebuggable 是否是 debug 模式(debug 模式会打印 debug 日志) Bool false Android
isHttps 是否使用https协议 Bool true Android和iOS
connectionTimeout 连接超时时间(单位是毫秒) Int Android(15000) iOS(30000) Android和iOS
socketTimeout 读写超时时间(单位是毫秒) Int 30000 Android
host 设置除了 GetService 请求外的 host String null Android和iOS
hostFormat 设置 host 的格式化字符串,sdk 会将 ${bucket} 替换为真正的 bucket,${region} 替换为真正的 region例如将 hostFormat 设置为 ${bucket}.${region}.tencent.com,并且您的存储桶和地域分别为 bucket-1250000000 和 ap-shanghai,那么最终的请求地址为 bucket-1250000000.ap-shanghai.tencent.com注意,这个设置不会影响 GetService 请求 String null Android
port 设置请求的端口 Int null Android
signInUrl 是否将签名放在 URL 中,默认放在 Header 中 Bool false Android
userAgent ua 拓展参数 String null Android和iOS
dnsCache 是否开启 DNS 解析缓存,开启后,将 DNS 解析的结果缓存在本地,当系统 DNS 解析失败后,会使用本地缓存的 DNS 结果 Bool true Android
accelerate 是否使用全球加速域名 Bool false Android和iOS

TransferConfig 用于配置 COS 上传服务,其主要成员说明如下:

参数名称 描述 类型 默认值 支持平台 必选
forceSimpleUpload 是否强制使用简单上传 Bool false Android
enableVerification 分片上传时是否整体校验 Bool true Android和iOS
divisionForUpload 设置启用分块上传的最小对象大小 Int 2097152 Android和iOS
sliceSizeForUpload 设置分块上传时的分块大小 Int 1048576 Android和iOS

第四步:访问 COS 服务

上传对象

SDK 支持上传本地文件、二进制数据。下面以上传本地文件为例:

    // 获取 TransferManager    CosTransferManger transferManager = Cos().getDefaultTransferManger();    //CosTransferManger transferManager = Cos().getTransferManger("newRegion");    // 存储桶名称,由 bucketname-appid 组成,appid 必须填入,可以在 COS 控制台查看存储桶名称。 https://console.cloud.tencent.com/cos5/bucket    String bucket = "examplebucket-1250000000";    String cosPath = "exampleobject"; //对象在存储桶中的位置标识符,即称对象键    String srcPath = "本地文件的绝对路径"; //本地文件的绝对路径    //若存在初始化分块上传的 UploadId,则赋值对应的 uploadId 值用于续传;否则,赋值 null    String? _uploadId;
// 上传成功回调 successCallBack(result) { // todo 上传成功后的逻辑 } //上传失败回调 failCallBack(clientException, serviceException) { // todo 上传失败后的逻辑 if (clientException != null) { print(clientException); } if (serviceException != null) { print(serviceException); } } //上传状态回调, 可以查看任务过程 stateCallback(state) { // todo notify transfer state } //上传进度回调 progressCallBack(complete, target) { // todo Do something to update progress... } //初始化分块完成回调 initMultipleUploadCallback( String bucket, String cosKey, String uploadId) { //用于下次续传上传的 uploadId _uploadId = uploadId; } //开始上传 TransferTask transferTask = await transferManager.upload(bucket, cosPath, filePath: srcPath, uploadId: _uploadId, resultListener: ResultListener(successCallBack, failCallBack), stateCallback: stateCallback, progressCallBack: progressCallBack, initMultipleUploadCallback: initMultipleUploadCallback ); //暂停任务 transferTask.pause(); //恢复任务 transferTask.resume(); //取消任务 transferTask.cancel();

下载对象

    // 高级下载接口支持断点续传,所以会在下载前先发起 HEAD 请求获取文件信息。    // 如果您使用的是临时密钥或者使用子账号访问,请确保权限列表中包含 HeadObject 的权限。
// TransferManager 支持断点下载,您只需要保证 bucket、cosPath、savePath // 参数一致,SDK 便会从上次已经下载的位置继续下载。
// 获取 TransferManager CosTransferManger transferManager = Cos().getDefaultTransferManger(); //CosTransferManger transferManager = Cos().getTransferManger("newRegion"); // 存储桶名称,由 bucketname-appid 组成,appid 必须填入,可以在 COS 控制台查看存储桶名称。 https://console.cloud.tencent.com/cos5/bucket String bucket = "examplebucket-1250000000"; String cosPath = "exampleobject"; //对象在存储桶中的位置标识符,即称对象键 String downliadPath = "本地文件的绝对路径"; //保存到本地文件的绝对路径
// 下载成功回调 successCallBack(result) { // todo 下载成功后的逻辑 } //下载失败回调 failCallBack(clientException, serviceException) { // todo 下载失败后的逻辑 if (clientException != null) { print(clientException); } if (serviceException != null) { print(serviceException); } } //下载状态回调, 可以查看任务过程 stateCallback(state) { // todo notify transfer state } //下载进度回调 progressCallBack(complete, target) { // todo Do something to download progress... } //开始下载 TransferTask transferTask = await transferManager.download(bucket, cosPath, downliadPath, resultListener: ResultListener(successCallBack, failCallBack), stateCallback: stateCallback, progressCallBack: progressCallBack ); //暂停任务 transferTask.pause(); //恢复任务 transferTask.resume(); //取消任务 transferTask.cancel();



对象存储官网1折活动,限时活动,即将结束,速速收藏
同尘科技为腾讯云授权服务中心。
购买腾讯云产品享受折上折,更有现金返利。同意关联立享优惠

转转请注明出处:http://www.yunxiaoer.com/145556.html

(0)
上一篇 2023年12月9日
下一篇 2023年12月9日
详情页2

相关推荐

  • 腾讯云对象存储设置文档预览

    简介 您可以通过对象存储控制台,对存储桶中的文档进行预览,本文介绍如何通过控制台使用 COS 的文档预览功能。关于文档预览的相关说明,请参见 文档预览概述。注意文档预览功能支持中国大陆公有云地域以及硅谷、弗吉尼亚、法兰克福、新加坡地域,其中新加坡和硅谷地域目前仅支持文档转图片预览。文档预览功能为收费项,由数据万象收取,具体费用请参见 计费与定价。数据万象在每…

    腾讯云 2023年12月9日
  • 阿里云ECS云服务器高可用架构部署方案-云淘科技

    高可用架构提供业务分发、弹性扩展、多可用区部署等功能。相较于使用单台ECS实例部署数据库与应用,高可用架构只需简单部署,并且拥有更高的稳定性和可扩展性。 高可用架构特点 高可用架构具有如下特点: 使用多可用区高可用版的负载均衡CLB(Classic Load Balancer)对多台云服务器ECS进行流量分发,可扩展应用系统对外服务能力、消除单点故障,提升应…

    阿里云服务器 2023年12月9日
  • 腾讯云云函数(SCF)应用性能观测-云淘科技

    简介 应用性能监控(Application Performance Management ,APM)是一款应用性能管理平台,基于实时的多语言应用探针全量采集技术,为您提供分布式应用性能分析和故障自检能力,全方位保障系统的可用性和稳定性。协助您在复杂的业务系统快速定位性能问题,降低 MTTR(平均故障恢复时间)。实时了解并追踪应用性能情况,提升用户体验。AP…

    2023年12月9日
  • 信息流广告,信息流部分建议宽度830px,只针对默认列表样式,顺序随机
  • 腾讯云TDSQL-C MySQL版安全审计

    TDSQL-C MySQL 版提供安全审计能力,对数据库管理系统访问行为与操作行为进行监控与记录,以便对数据库管理系统中安全事件进行审计或其它安全防范操作。 合规审计 TDSQL-C MySQL 版提供企业级的合规审计功能,其具有合规、安全、追溯等特性,符合国家相关规定,是用户通过等保合规的刚需产品。合规审计通过对用户访问数据库行为的记录、分析,帮助用户事后…

    腾讯云 2023年12月9日
  • 腾讯云对象存储复制与移动对象

    简介 本文档提供关于对象的复制、移动操作相关的 API 概览以及 SDK 示例代码。简单操作 API 操作名 操作描述 PUT Object – Copy 设置对象复制(修改对象属性) 复制文件到目标路径 分块操作 API 操作名 操作描述 Initiate Multipart Upload 初始化分块上传/复制 初始化分块上传/复制操作 Upl…

    腾讯云 2023年12月9日

联系我们

400-800-8888

在线咨询: QQ交谈

邮件:admin@example.com

工作时间:周一至周五,9:30-18:30,节假日休息

关注微信
本站为广大会员提供阿里云、腾讯云、华为云、百度云等一线大厂的购买,续费优惠,保证底价,买贵退差。