swiftui接入腾讯云对象存储cos

news/2024/11/29 19:15:04/

​个人来说玩玩,还是用swiftui比较好,毕竟写界面的速度快很多,而且还比较直观。
有部分逻辑需要接入图片上传,因此接入了一下腾讯云对象存储cos。
官网上只有swift的教程,没有swiftui的。记录一下swiftui的接入过程。

首先引入pod集成项目。

pod 'QCloudCOSXML' 
# 据说是精简版,不过看起来好像也没有啥效果,头文件的引入好像根据文档来还是会报错的。
# 本例子只是简单的上传,因此用哪个都行。
# pod 'QCloudCOSXML/Transfer' 

引入头文件

import QCloudCOSXML
// 精简版用下边的这个好像会报错,找不到这个,用上边的没问题
// import QCloudCOSXMLTransfer 

初始化

一般来说swiftui的app部分是这样的。不过按照教程直接继承协议是不行的。

@main
struct DemoApp: App {var body: some Scene {WindowGroup {ContentView()}}
}

首先新建一个 appdelegate

class AppDelegate: NSObject, UIApplicationDelegate, QCloudSignatureProvider {}

然后在里边实现初始化及签名的回调。这两部分感觉不用写在appdelegate的finish launch里边,因为现在的应用一般还要来个隐私协议。暴露出一个方法来给swiftui调用,控制流程比较方便。最好粘贴代码,不要手敲,例如 QCloudAuthentationV5Creator 这个有个虚方法QCloudAuthentationCreator,稍不注意就失败了。
另外本例子用的是客户端直接同cos通讯方式,如果出现泄漏直接换secret也是可行的。

class AppDelegate: NSObject, UIApplicationDelegate, QCloudSignatureProvider {func signature(with fileds: QCloudSignatureFields!, request: QCloudBizHTTPRequest!, urlRequest urlRequst: NSMutableURLRequest!, compelete continueBlock: QCloudHTTPAuthentationContinueBlock!) {let credential = QCloudCredential.init()credential.secretID = "xxx" // 密钥IDcredential.secretKey = "xxx" // 密钥secretlet creator = QCloudAuthentationV5Creator.init(credential: credential)let signature = creator?.signature(forData: urlRequst)continueBlock(signature, nil)}func initQCloud() {let config = QCloudServiceConfiguration.init()let endpoint = QCloudCOSXMLEndPoint.init()endpoint.regionName = "ap-beijing" // bucket regionendpoint.useHTTPS = trueconfig.endpoint = endpointconfig.signatureProvider = selfQCloudCOSXMLService.registerDefaultCOSXML(with: config)QCloudCOSTransferMangerService.registerDefaultCOSTransferManger(with: config)}
}

把appdelegate加入到swiftui的app中。

struct DemoApp: App {@UIApplicationDelegateAdaptor(AppDelegate.self) var delegatevar body: some Scene {WindowGroup {ContentView().onAppear {delegate.initQCloud()}}}
}

初始化到此完毕。
初始化完整代码:

import SwiftUI
import QCloudCOSXMLclass AppDelegate: NSObject, UIApplicationDelegate, QCloudSignatureProvider {func signature(with fileds: QCloudSignatureFields!, request: QCloudBizHTTPRequest!, urlRequest urlRequst: NSMutableURLRequest!, compelete continueBlock: QCloudHTTPAuthentationContinueBlock!) {let credential = QCloudCredential.init()credential.secretID = "xxx" // 密钥IDcredential.secretKey = "xxx" // 密钥secretlet creator = QCloudAuthentationV5Creator.init(credential: credential)let signature = creator?.signature(forData: urlRequst)continueBlock(signature, nil)}func initQCloud() {let config = QCloudServiceConfiguration.init()let endpoint = QCloudCOSXMLEndPoint.init()endpoint.regionName = "ap-beijing" // bucket regionendpoint.useHTTPS = trueconfig.endpoint = endpointconfig.signatureProvider = selfQCloudCOSXMLService.registerDefaultCOSXML(with: config)QCloudCOSTransferMangerService.registerDefaultCOSTransferManger(with: config)}
}struct DemoApp: App {@UIApplicationDelegateAdaptor(AppDelegate.self) var delegatevar body: some Scene {WindowGroup {ContentView().onAppear {delegate.initQCloud()}}}
}

上传部分

简单上传部分

import QCloudCOSXMLfunc updatePic(img: UIImage) {let picPath = "temp/\(Day(date: date).format(format: "yyyy-MM-dd"))/\(UUID().uuidString).png"let put = QCloudCOSXMLUploadObjectRequest<AnyObject>()put.bucket = "xxx" // bucket idput.object = picPath // 上传路径put.body = img.pngData() as AnyObjectput.setFinish { res, err inprint("upload obj finish \(res) \(err)")}QCloudCOSTransferMangerService.defaultCOSTransferManager().uploadObject(put)
}

到此cos接入完毕。


http://www.ppmy.cn/news/789936.html

相关文章

Docker中部署Redis集群与部署微服务项目的详细过程

目录 一、使用Docker部署的好处二、Docker 与 Kubernetes 对比三、Redis集群部署实战四、Spring Boot项目 打包镜像?小结 一、使用Docker部署的好处 Docker的好处在于&#xff1a;在不同实例上运行相同的容器 Docker的五大优点&#xff1a; 持续部署与测试、多云服务平台支…

原码、反码、补码基本概念

基本概念 原码:符号位加上真值的绝对值&#xff0c;也就是第一位表示符号。其余位表示值&#xff08;0为正值&#xff0c;1为负值&#xff09; 原码是人脑最容易理解和计算的表示方式 反码&#xff1a;正数的反码是其本身&#xff0c;负数的反码是在其原码的基础上符号位不变&…

PS切图保存后的背景图为透明

1、若想PS切图保存后的背景图为透明&#xff0c;那么则需要在如下图中所示的修改即可&#xff0c;切图后【文件】——>【存储为web格式】——>【PNG-24】&#xff1a; 2、要想在css中的背景图片为相通&#xff0c;则先剪切一个小个的图&#xff0c;然后再选择background&…

PS教程新手入门(二)--保存清晰透明的.Png格式图片的方法和技巧教程

.Png格式是图像文件存储格式&#xff0c;在网页设计中已经不是一个陌生的名词&#xff0c;在前端开发中经常使用到它&#xff0c;本文是对.PNG格式的详细介绍&#xff0c;并且针对网页设计上.PNG格式的使用做了相关说明。Png有多少种格式&#xff1f;有哪些特点&#xff1f;网页…

photoshop保存背景透明图片办法

将图片背景删除&#xff0c;保存为png格式即可&#xff0c;注意颜色必须为RGB模式&#xff0c;否则存储为中找不到png这个格式。

PS制作透明图片png格式

这期主要介绍ps如何制作png透明图片&#xff0c;生活中总是出现各种透明背景图标等需求&#xff08;PPT、网站等地方&#xff09;&#xff0c;所以就专门为平面设计写一期博客。 文章目录 1 选择主体图2 复制图层3 新建图片4 粘贴图层5 保存 1 选择主体图 快速选择工具 2 复…

PhotoShop 选中区域 变透明 透明化 导出图片

文章目录 Intro相关软件图片的透明部分PhotoShop 选中图片部分区域 将其变透明 导出图片打开图片对图层“去锁”使用索套工具选中指定区域按Delete删除选中区域(该区域变为透明)导出图片 另外一种导出方式reference Intro HTML中多张图片重叠时设置图片的不透明度&#xff0c;…

C语言 常用库函数-表

文章目录 一、数学函数二、字符函数三、字符串函数四、输入输出函数五、动态分配函数和随机函数 一、数学函数 调用数学函数时&#xff0c;要求在源文件中包下以下命令行&#xff1a; #include <math.h> 二、字符函数 调用字符函数时&#xff0c;要求在源文件中包下以…