小程序云开发数据库API
发表时间:2020-10-27
发布人:葵宇科技
浏览次数:64
小程序云开发HTTP API使用
本人使用Python3.X作为开发版本,其他语言类似,格式自己调一下(requests.post发请求)
主要用于,作为与小程序关联的数据提供平台,使用脚本或者开发WEB端平台为小程序提供数据、或作为小程序的数据的管理端(CRUD)
在完成小程序认证、小程序项目创建后(要勾选云开发),可以在小程序控制台(开发-开发设置)获取你的AppID(小程序ID)以及AppSecret(小程序密钥)并在成员管理中为添加开发者权限
小程序秘钥只能查看一次,再次查看会重置(切记保存)
以下为API调用:
云开发有各种调用限制,免费环境为5万次读请求,3万次写请求,access_token获取有次数限制(具体在文档里找一下),任一次数超过调用上限即会被停服到隔天凌晨1点左右,小程序控制台有每月10次清空调用次数
首先获取小程序access_token(有效时间120min,且再次获取,上次的会失效)
GRANT_TYPE = 'client_credential'
APP_ID = '你的AppID'
APP_SECRET = '你的AppSecret'
url = 'https://api.weixin.qq.com/cgi-bin/token?grant_type={0}&appid={1}&secret{2}'.format(GRANT_TYPE,APP_ID,APP_SECRET)
response = requests.get(url)
result = response.json()
# 如果频繁使用的话可以把token写到一个txt文件中,但小程序没有提供token是否有效的接口
print(result['access_token'])
新增集合(数据表)
url = 'https://api.weixin.qq.com/tcb/databasecollectionadd?access_token={0}'.format(access_token)
data = {
'env':'环境名',
'collection_name': '集合名称'
}
requests.post(url, data=json.dumps(data))
新增完集合后,CRUD基本差不太多
# url有些区别(第一个是count集合有多少数据)
url = 'https://api.weixin.qq.com/tcb/databasecount?access_token={}'.format(access_token)
url = 'https://api.weixin.qq.com/tcb/databaseadd?access_token={}'.format(access_token)
url = 'https://api.weixin.qq.com/tcb/databasedelete?access_token={}'.format(access_token)
url = 'https://api.weixin.qq.com/tcb/databaseupdate?access_token={}'.format(access_token)
url = 'https://api.weixin.qq.com/tcb/databasequery?access_token={}'.format(access_token)
# 小程序的sql语句
"""
小程序常用数据类型string、number(包括整型和浮点型)、array(数组)对应python字符串格式化
'%s'、%d、%s,字符串要用引号包起来,数字不能用引号,str(list)传入
query = "db.collection('集合名称').where({字段名:'条件'})
.add({data:{[键:'值']}})/remove()/update({data:{键:'值'}})/get()"
"""
# get还可以加“.limit().skip()”加载get()之前,limit服务端默认为10,最大为1000
# 组织数据包
data = {
"env": "你的环境名称在开发工具内找到",
"query": query
}
# 字符串格式化后一定要转成json字符串
response = requests.post(url, data=json.dumps(data))
print(response.json())
基本的增删改查如果不能满足你的需求,那你可以试一下极其难用的聚合操作
# 除url和query语句不同外,基本相同,写db_handle类时可以提高复用性
url = 'https://api.weixin.qq.com/tcb/databaseaggregate?access_token={}'.format(access_token)
# 下面是我在开发是用过的一个简单的聚合(自己调一下缩进)
query = "db.collection('Book_information').aggregate()
.match({'is_delete':0}).sort({create_time:-1})
.lookup({
from:'user_books',
localField:'book_name',
foreignField:'book_name',
as:'book_info'})
.skip(%d).limit(10).end()" % (page * 10)
"""
.aggregate():发起聚合操作
.match():等于普通语句的.where()
排序可以多字段排序
聚合阶段: .sort({'字段名':-1,'多字段'}):根据某一字段排序,-1降序
普通查询: .orderBy('字段名','asc').orderBy(多字段写多个)
.group({
_id:$表内字段名,
num:$.sum(1),
支持多字段,但多字段都为累加值,需要使用算数运算符
})
选择输出字段:
聚合阶段: .project({多字段,_id默认保留})
普通查询: .field({多字段,选择要输出的字段名})
.lookup():连表查询,上方演示为二种中的一种
from:'连接的表名',
localField:'主表要连接的字段',
foreignField:'连接表的字段两者相等即连接',
as:'book_info'(连接后,key为book_info,value为列表)
.end():聚合阶段结束
"""
还有一个细节问题,普通查询中,算数运算符和逻辑运算符要用“_.or”,而聚合操作中要使用“$.or”使用
常用逻辑运算符_.and/_.or
单字段
_.and({_.gt(50),_.(100)}) 或者 _.gt(50).and(_.lt(100))
多字段
_.and([{ progress: _.gt(50)},{tags: 'cloud'}])
where或match中多条件默认带and
比较运算符
聚合阶段时包括当前集合的字段名也要使用“$.”
gt 大于 llt 小于 eq 等于
gte 大于等于 lte 小于等于 neq 不等于
还有普通查询特有
in,nin,可直接传入一个数组
# 最后还有一个上传文件到存储
path = '文件路径'
url = "https://api.weixin.qq.com/tcb/uploadfile?access_token={}".format(access_token)
data = {
"env": "环境名称",
"path": "文件路径(需要带文件后缀名)"
}
response = requests.post(url, data=json.dumps(data))
result = response.json()
file = {"file": open(path, "rb")}
# 两个data中的文件路径为小程序云存储中的路径,文件夹好像是要提前创建
data = {
'key': '和data['path']相同',
'Signature': result['authorization'],
'x-cos-security-token': result['token'],
'x-cos-meta-fileid': result['cos_file_id']
}
requests.post(result['url'], data=data, files=file)
# 获取下载连接的话去存储里找一个直接拼接就可以了
'https://[这里有一个环境名需要找].tcb.qcloud.la/news_images/1601278105.5322824.jpg'
小程序开发者社区是个鬼社区,我只能帮你到这里了~