这是小程序开发第二篇,主要介绍如何上传图片到腾讯云,之所以选择腾讯云,是因为腾讯云免费空间大
上传图片主要是将图片上传到腾讯云对象存储(COS)。
要使用对象存储 API,需要先执行以下步骤:
所以我们要做的准备工作有:
这些配置过程这里就不做说明了,接下来主要介绍步骤4、5。
小程序上传图片到 cos 流程如下图:
在这个过程中我们需要实现的是,鉴权服务器返回签名的步骤以及小程序的相关步骤。
使用对象存储服务 COS 时,可通过 RESTful API 对 COS 发起 HTTP 匿名请求或 HTTP 签名请求,对于签名请求,COS 服务器端将会进行对请求发起者的身份验证。
上传图片是一个签名请求,需要进行签名验证。之所以我们
签名流程
客户通过对 HTTP 请求进行签名,并将签名后的请求发送至腾讯云进行签名验证,具体流程如下图所示。
我们使用 sdk 开发,这个流程大致了解下就行,签名的实现 sdk 已经包含,只需要调用方法即可。
通过签名流程我们可以知道,签名需要 SecretId 和 SecretKey,这两个信息不适合存放在客户端中,这也是我们单独部署一个鉴权服务器的主要原因。
签名生成 API
上一篇小程序开发:python sanic 实现小程序登录注册 我们介绍过,服务端使用 sanic 框架 + swagger_py_codegen 生成 rest-api。
添加签名生成 api 我们需要先在文档中添加 API 的相关描述。文档代码:https://github.com/gusibi/Metis/blob/master/docs/v1.yml
这个接口我们要求登录才能调用。
文档定义完成之后,调用
生成代码模板,API 代码实现如下:
由于 腾讯云COSv4 的Python SDK 只支持 python2,而 sanic 需要 python3.5+ 所以,这里我 fork 出来一份添加了 python3 的支持。
https://github.com/gusibi/cos-python-sdk-v4。使用 python3 环境的可以使用这个版本。
选择图片
wx.chooseImage(OBJECT)
从本地相册选择图片或使用相机拍照。
调用这个方法,小程序会把选择的图片放到临时路径(在小程序本次启动期间可以正常使用,如需持久保存,需在主动调用 wx.saveFile,在小程序下次启动时才能访问得到),我们只能将临时路径的文件上传。
核心代码如下:
这里图片选择成功后,我们取原图上传到 cos。
上传图片
cos 上传图片的URL由 cos_region,appid,bucket_name和 cos_dir_name 拼接而成。
把以下字段配置成自己的cos相关信息,详情可看API文档
REGION: cos上传的地区
APPID: 账号的appid
BUCKET_NAME: cos bucket的名字
DIR_NAME: 上传的文件目录
小程序提供了 uploadTask.onProgressUpdate() 来获取图片的上传进度,这里我将图片的上传进度显示了出来。
完整代码参考:metis-wxapp: https://github.com/gusibi/Metis-wxapp
留言与评论(共有 0 条评论) |