云函數
云函數是一段運行在云端的代碼,無需管理服務器,在開發工具內編寫、一鍵上傳部署即可運行后端代碼。
小程序內提供了專門用于云函數調用的 API。開發者可以在云函數內使用 wx-server-sdk 提供的 getWXContext 方法獲取到每次調用的上下文(appid、openid 等),無需維護復雜的鑒權機制,即可獲取天然可信任的用戶登錄態(openid)。
1. 云函數創建
根據官網提示,創建一個云函數,命名為 add, 功能是將 a , b 兩數相加,步驟如下:
在文件夾 cloudfunctions 目錄下創建文件夾 add, 編輯add中的index.js文件:
// 云函數入口文件
const cloud = require('wx-server-sdk')
// 云函數入口函數
exports.main = async (event, context) => {
console.log(event)
console.log(context)
const {a, b} = event
const {OPENID, APPID} = cloud.getWXContext() // 這里獲取到的 openId 和 appId 是可信的
const sum = a + b
return {
OPENID,
APPID,
sum
}
}
在小程序中調用這個云函數前,我們還需要先將該云函數部署到云端。在云函數目錄上右鍵,在右鍵菜單中,我們可以將云函數整體打包上傳并部署到線上環境中。
2. 云函數調用
部署完成后,我們可以在小程序中調用該云函數:
//小程序端調用方法
wx.cloud.callFunction({
// 需要調用的云函數名
name: 'sum',
// 傳給云函數的參數
data: {
a: 1,
b: 2,
},
success: function(res) {
console.log(res.result.sum) // 3
},
fail: function(err) {
console.log(err)
}
})
也可以使用 Promise 調用方式:
wx.cloud.callFunction({
// 云函數名稱
name: 'add',
// 傳給云函數的參數
data: {
a: 1,
b: 2,
},
}).then(res => {
console.log(res.result) // 3
})
.catch(console.error)