uniCloud开发api接口服务
Posted 阿晨学前端
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了uniCloud开发api接口服务相关的知识,希望对你有一定的参考价值。
首先创建一个云对象:
在创建的云对象的index.Obj.js中进行编码:
const db = uniCloud.database()
module.exports =
_before: function () // 通用预处理器
,
async get()
//demo-user 是云数据中的一个表名
let res = await db.collection("demo-user").limit(2).get()
return res
开启本地运行,查看效果:开启后会增加一个demoObj.param.js文件
开启运行:
_before预处理
我们如何将参数传递给api接口中呢,需要在_before中处理。传递参数如下:
get(
num: 1
)
获取参数如下:
const db = uniCloud.database()
module.exports =
_before: function() // 通用预处理器
// 获取当前参数列表,固定接口形式:this.getParams()
this.params = this.getParams()[0]
,
async get()
let
num
= this.params
let res = await db.collection("demo-user").limit(num).get()
let result =
errCode:0,
errMsg:"查询成功",
data:res.data
return result
查询结果如下:
_after 后处理:用来再加工处理本次调用方法的返回结果或者抛出的错误
const db = uniCloud.database()
module.exports =
_before: function() // 通用预处理器
// 获取当前参数列表,固定接口形式:this.getParams()
this.params = this.getParams()[0]
// 在before内记录开始时间并在this上挂载,以供后续流程使用
this.startTime = Date.now()
,
async get()
let
num
= this.params
let res = await db.collection("demo-user").limit(num).get()
let result =
errCode: 0,
errMsg: "查询成功",
data: res.data
return result
,
_after(error, result)
if (error)
throw error // 如果方法抛出错误,也直接抛出不处理
result.text = "测试抛出"
result.timeCost = Date.now() - this.startTime
return result
上述中是在后处理中处理请求时间,请求后返回如下:
通过 HTTP URL 方式访问云对象
将本地没有问题的云对象上传部署:
获取url地址:
后面的路径可以自己配置,用来区分不同接口
然后就是用postman模拟请求:
首先云对象默认是post请求;其次路径后面的“/get”,是跟index.Obj.js中定义的方法一致;然后form-data格式就可以在预处理那获取参数了
JSON格式如何获取:
const db = uniCloud.database()
module.exports =
_before: function() // 通用预处理器
// this.getHttpInfo()获取JSON形式的数据
this.param = JSON.parse(this.getHttpInfo().body)
,
async get()
let num = this.param
let res = await db.collection("demo-user").limit(Number(num)).get()
let result =
errCode: 0,
errMsg: "成功",
data: res.data
return result
云对象调用公共模块:
首先先定义一个公共模块:
module.exports =
myFun(e)
return `我是$e 我要学习unicloud`
然后在云对象中调用:
调用前保证云对象下面有package.json文件,没有就执行npm init -y
生成package.json
文件,然后打开命令行
执行npm install ../common/demo-text
引入demo-text
模块,然后在云对象中引用并使用:
最后postman测试效果:
小程序云开发转uniCloud阿里云
为啥要改呢?因为微信小程序的云开发要收费了,19.9每个月,所以改成用uniCloud的阿里云,免费!
大概思路:小程序转成uniapp,小程序云开发改用uniCloud,云存储也是用uniCloud,api调用都用uniApp的,那里需要改就改哪里
一、小程序 转译成uniapp
1、利用插件进行转译 可参考以下文章
https://blog.csdn.net/banglei123/article/details/103741149
注意:小程序要去掉骨架屏文件再转,不然转过来无法运行
2、转译完成后,在HBulider X中打开,编译到微信开发者工具中运行,不报错即转译成功
二、创建unicloud环境
1、在HBulider X 中右键文件 ———— 创建云环境 (腾讯云要收费,用阿里云的)
注:如果未进行实名认证,会跳转至实名认证页面进行实名认证,等待实名认证审核之后可以开通服务空间
创建服务空间可能需要几分钟的时间,可以在控制台查看是否创建完成
2、创建完成后会有默认的云函数文件夹和数据库文件夹
3、把小程序的云函数搬过来,修改云函数中的index.js文件,其他文件可以删除
4、修改index.js 云函数的编写和小程序的大差不差,修改引入方式即可
附上官网云函数文档:uni-app官网
5、修改调用云函数的api
wx.callFunction 改成 uniCloud.callFunction
6、搬云数据库数据
微信小程序云开发数据库有导出成json格式,uniCloud里面可以兼容,直接导入
7、由于项目需要获取openid 于是使用uniapp的uni-id-cf模块,可参考一下文章
小程序微信登录 uni-id-cf
自定义后的config.json 存放位置如图,需要自己创建uni-id文件夹和config.json文件,配置微信小程序的密钥和appid
注:
真机调试、预览、发布都要使用云端云函数
真机调试或者预览要打开小程序的开发者模式
本小程序是一个很小的练手项目,所涉及到的相关api较少,所以改动较少,大佬勿喷。
————本文章仅供参考
以上是关于uniCloud开发api接口服务的主要内容,如果未能解决你的问题,请参考以下文章