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接口服务的主要内容,如果未能解决你的问题,请参考以下文章

小程序云开发转uniCloud阿里云

uniCloud使用

前端 API 接口数据模拟 (Mock)

巧借api网关+云函数,一键获取微信小程序openid

uniCloud初体验

Eolink是国产API接口管理的无冕之王