Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
DCloud
unidocs-zh
提交
fefc29b9
unidocs-zh
项目概览
DCloud
/
unidocs-zh
通知
3216
Star
106
Fork
815
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
94
列表
看板
标记
里程碑
合并请求
70
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
unidocs-zh
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
94
Issue
94
列表
看板
标记
里程碑
合并请求
70
合并请求
70
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
fefc29b9
编写于
6月 29, 2022
作者:
W
wanganxp
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
提交普通云函数新版文档
上级
f8ee0e64
变更
1
显示空白变更内容
内联
并排
Showing
1 changed file
with
75 addition
and
65 deletion
+75
-65
docs/uniCloud/cf-callfunction.md
docs/uniCloud/cf-callfunction.md
+75
-65
未找到文件。
docs/uniCloud/cf-callfunction.md
浏览文件 @
fefc29b9
...
@@ -26,13 +26,15 @@ callFunction方式避免了服务器提供域名,不暴露固定ip,减少被
...
@@ -26,13 +26,15 @@ callFunction方式避免了服务器提供域名,不暴露固定ip,减少被
|字段 |类型 |说明 |
|字段 |类型 |说明 |
|:-: |:-: |:-: |
|:-: |:-: |:-: |
|result |Object |云函数
返回结果
|
|result |Object |云函数
中代码return的返回结果
|
|requestId |String |云函数请求序列号,用于错误排查,可以在uniCloud web控制台的云函数日志中查到 |
|requestId |String |云函数请求序列号,用于错误排查,可以在uniCloud web控制台的云函数日志中查到 |
|header |Object |服务器header信息 |
|header |Object |服务器header信息 |
|errCode |Number或String |服务器错误码 |
|errCode |Number或String |服务器错误码 |
|success |bool |执行是否成功 |
|success |bool |执行是否成功 |
注意:HBuilderX本地运行云函数时只返回result,其他需要在云端运行云函数才会返回
注意:HBuilderX本地运行云函数时只返回
`result`
,其他需要在云端运行云函数才会返回
返回格式,下文有详细解读
[
详见
](
?id=returnformat
)
**前端示例代码**
**前端示例代码**
...
@@ -60,7 +62,7 @@ uniCloud.callFunction({
...
@@ -60,7 +62,7 @@ uniCloud.callFunction({
客户端callFunction调用云函数时,云函数通过入参接收客户端数据,通过头信息上下文获取客户端信息,经过业务逻辑处理后给客户端返回结果。
客户端callFunction调用云函数时,云函数通过入参接收客户端数据,通过头信息上下文获取客户端信息,经过业务逻辑处理后给客户端返回结果。
假使客户端代码调用云函数
hellocf,并传递了{a:1,b:2}
的数据,
假使客户端代码调用云函数
`hellocf`
,并传递了
`{a:1,b:2}`
的数据,
```
js
```
js
// 客户端调用云函数并传递参数
// 客户端调用云函数并传递参数
uniCloud
.
callFunction
({
uniCloud
.
callFunction
({
...
@@ -76,78 +78,91 @@ uniCloud.callFunction({
...
@@ -76,78 +78,91 @@ uniCloud.callFunction({
'
use strict
'
;
'
use strict
'
;
exports
.
main
=
async
(
event
,
context
)
=>
{
exports
.
main
=
async
(
event
,
context
)
=>
{
//event为客户端上传的参数
//event为客户端上传的参数
let
c
=
event
.
a
+
event
.
b
return
{
return
{
sum
:
event
.
a
+
event
.
b
sum
:
c
}
// 通过return返回结果给客户端
}
// 通过return返回结果给客户端
}
}
```
```
云函数的传入参数有两个,一个是
`event`
对象,一个是
`context`
对象。
云函数的传入参数有两个,一个是
`event`
对象,一个是
`context`
对象。
-
`event`
指的是触发云函数的事件。当客户端调用云函数时,
`event`
就是客户端调用云函数时传入的参数。
-
`event`
指的是触发云函数的事件。当客户端调用云函数时,
`event`
就是客户端调用云函数时传入的参数。
-
`context`
对象包含了本次请求的上下文,包括客户端的操作系统(
`os`
)、运行平台(
`platform`
)、应用信息(
`appid`
)
-
`context`
对象包含了本次请求的上下文,包括客户端的ip、ua、appId等信息,以及云函数的环境情况、调用来源source等信息。
### event对象
event对象,可以理解为客户端上行参数中的json对象。在使用
`uni-id`
且登录成功后,会自动多添加了一个
`uniIdToken`
属性。
如下是一个示例
:
可以通过
`event.uniIdToken`
获取 uni-id 的 token,如下
:
```
js
```
js
'
use strict
'
;
'
use strict
'
;
exports
.
main
=
async
(
event
,
context
)
=>
{
exports
.
main
=
async
(
event
,
context
)
=>
{
//event为客户端上传的参数
let
token
=
event
.
uniIdToken
// 客户端uni-id token
//...
//context中可获取客户端调用的上下文
let
clientIP
=
context
.
CLIENTIP
// 客户端ip信息
let
clientUA
=
context
.
CLIENTUA
// 客户端user-agent
let
spaceInfo
=
context
.
SPACEINFO
// 当前环境信息 {spaceId:'xxx',provider:'tencent'}
// 以下四个属性只有使用uni-app以callFunction方式调用才能获取,调用方不是uni-app客户端则没有相应数据
let
os
=
context
.
OS
//客户端操作系统,返回值:android、ios 等
let
platform
=
context
.
PLATFORM
//运行平台,返回值为 mp-weixin、app-plus等。注意:vue3版本uni-app将app-plus修改为了app,此处为保证旧版本兼容性未进行统一,推荐后续在业务中都使用app作为客户端标识
let
appid
=
context
.
APPID
// manifest.json中配置的appid
let
deviceId
=
context
.
DEVICEID
// 客户端标识,新增于HBuilderX 3.1.0,同uni-app客户端getSystemInfo接口获取的deviceId
//... //其它业务代码
}
}
```
```
**注意:下面所有的“客户端”均是相对于云函数而言,如果你使用自己的服务器调用云函数,此时客户端是指你的服务器**
所以开发者需注意,自己上行的参数对象不要包含uniIdToken属性,避免同名冲突。
### 获取用户token@client-token
**入参的体积限制**
如果客户端在storage内存储了uni_id_token,在使用callFunction请求云函数时会自动将此token传递到云端,云端可以通过以下方式获取:
云函数上行的参数内容不能传太大。
```
js
-
阿里云event大小不可超过1MB
'
use strict
'
;
-
腾讯云event大小不可超过6MB
exports
.
main
=
async
(
event
,
context
)
=>
{
let
token
=
event
.
uniIdToken
// 客户端uni-id token
}
```
###
获取客户端IP@clientip
###
context对象
```
js
-
`context`
对象包含了本次请求的上下文,包括客户端的ip、ua、appId等信息,以及云函数的环境情况、调用来源source等信息。
'
use strict
'
;
exports
.
main
=
async
(
event
,
context
)
=>
{
let
clientIP
=
context
.
CLIENTIP
// 客户端ip信息
}
```
### 获取客户端user-agent@client-user-agent
context对象的属性清单如下:
```
js
|属性名称 |类型 |说明 |
'
use strict
'
;
|-- |-- |-- |
exports
.
main
=
async
(
event
,
context
)
=>
{
|SPACEINFO |object |服务空间信息 |
let
clientUA
=
context
.
CLIENTUA
// 客户端user-agent信息
|
|
- spaceId |string |服务空间id |
}
|
|
- provider |string |服务空间供应商:aliyun
|
tencent |
```
|SOURCE |string |云函数调用来源
[
详见
](
?id=context-source
)
|
|FUNCTION_NAME |string |获取云函数名称 |
|CLIENTIP |string |客户端IP。如果调用来源是其他服务器,会返回调用方的ip|
### 获取服务空间信息@context-space-info
除了上述属性,如果是uni-app客户端通过callfunction访问云函数,那么context还会追加一批客户端信息。
-
HBuilderX 3.4.9前,context 添加了一批大写属性,如APPID、OS。
-
HBuilderX 3.4.9起,context 的属性包括前端API
`uni.getSystemInfo`
的所有属性。比如appId、osName,均以驼峰方式命名。这些属性较多,且可能跟随前端API更新而变化,具体详见
[
uni.getSystemInfo
](
/api/system/info.html#getsysteminfo
)
为了保持向下兼容,新版并没有去掉老版那些大写属性的客户端信息,但文档标注为以废弃。对于新版HBuilderX用户而言,请使用
`uni.getSystemInfo`
返回的驼峰属性。
示例:
```
js
```
js
'
use strict
'
;
'
use strict
'
;
exports
.
main
=
async
(
event
,
context
)
=>
{
exports
.
main
=
async
(
event
,
context
)
=>
{
//event为客户端上传的参数
//...
//context中可获取客户端调用的上下文
let
clientIP
=
context
.
CLIENTIP
// 客户端ip信息
let
spaceInfo
=
context
.
SPACEINFO
// 当前环境信息 {spaceId:'xxx',provider:'tencent'}
let
spaceInfo
=
context
.
SPACEINFO
// 当前环境信息 {spaceId:'xxx',provider:'tencent'}
let
source
=
context
.
SOURCE
// 云函数调用来源
// 以下属性只有使用uni-app以callFunction方式调用才能获取,即context.SOURCE=="client",调用方不是uni-app客户端则没有相应数据
let
appid
=
context
.
appId
// manifest.json中配置的appid
let
deviceId
=
context
.
deviceId
// 客户端标识,新增于HBuilderX 3.1.0,同uni-app客户端getSystemInfo接口获取的deviceId
//... //其它业务代码
}
}
```
```
### 获取云函数调用来源@context-source
### 获取云函数调用来源@context-source
context.SOURCE,返回云函数调用来源,它的值域为:
|取值 |解释 |
|-- |-- |
|client |客户端callFunction方式调用 |
|http |云函数url化方式调用 |
|timing |定时触发器调用 |
|function |由其他云函数callFunction调用 |
|server |由uniCloud管理端调用,HBuilderX里上传并运行|
```
js
```
js
'
use strict
'
;
'
use strict
'
;
exports
.
main
=
async
(
event
,
context
)
=>
{
exports
.
main
=
async
(
event
,
context
)
=>
{
...
@@ -160,30 +175,14 @@ exports.main = async (event, context) => {
...
@@ -160,30 +175,14 @@ exports.main = async (event, context) => {
}
}
```
```
### 其他客户端信息@client-info
> HBuilderX 3.4.9起,可以获取所有客户端`getSystemInfo`返回的客户端信息,详细字段列表参考:[getSystemInfo](https://uniapp.dcloud.net.cn/api/system/info.html#getsysteminfo)
```
js
'
use strict
'
;
exports
.
main
=
async
(
event
,
context
)
=>
{
let
os
=
context
.
OS
//客户端操作系统,返回值:android、ios 等
let
platform
=
context
.
PLATFORM
//运行平台,返回值为 mp-weixin、app等。注意老版曾使用app-plus,具体见下
let
appid
=
context
.
APPID
// manifest.json中配置的appid
let
deviceId
=
context
.
DEVICEID
// 客户端标识,新增于HBuilderX 3.1.0,同uni-app客户端getSystemInfo接口获取的deviceId
}
```
**注意事项**
**注意事项**
-
客户端上报的信息在理论上存在被篡改可能,实际业务中应验证前端传来的数据的合法性
-
客户端上报的信息在理论上存在被篡改可能,实际业务中应验证前端传来的数据的合法性
-
`context.PLATFORM`
的取值,有
`app`
和
`app-plus`
两种情况。
-
`context.PLATFORM`
的取值,有
`app`
和
`app-plus`
两种情况。
*
uni-app的vue3版本取值为
`app`
*
uni-app的vue3版本取值为
`app`
*
vue2版本,在uni-app 3.4.9之前,取值为
`app-plus`
,uni-app 3.4.9起,该值修改为了
`app`
*
vue2版本,在uni-app 3.4.9之前,取值为
`app-plus`
,uni-app 3.4.9起,该值修改为了
`app`
-
阿里云event大小不可超过1MB,腾讯云event大小不可超过6MB
除了CLIENTIP外,其他客户端信息只有使用uni-app客户端以callFunction方式调用才能获取。如果云函数url化后被uni-app通过request调用,也没有客户端信息。
客户端信息只有使用uni-app客户端以callFunction方式调用才能获取,由客户端传递到云函数。如果云函数url化后被uni-app通过request调用,也没有客户端信息。
在云函数URL化的场景无法获取客户端平台信息,可以在调用依赖客户端平台的接口接口之前(推荐在云函数入口)通过修改context.PLATFORM手动传入客户端平台信息供其他插件(如:uni-id)使用
在云函数URL化的场景无法获取客户端平台信息,可以在调用依赖客户端平台的接口接口之前(推荐在云函数入口)通过修改context.PLATFORM手动传入客户端平台信息供其他插件(如:uni-id)使用
...
@@ -195,11 +194,11 @@ exports.main = async (event, context) => {
...
@@ -195,11 +194,11 @@ exports.main = async (event, context) => {
}
}
```
```
## 云函数的返回格式
## 云函数的返回格式
@returnformat
普通云函数返回给客户端的是json格式数据。返回结果包裹在result下。
普通云函数返回给客户端的是json格式数据。返回结果包裹在result下。
前端发起callFunction到云端接收参数并响应,然后反馈前端,
然后前端接收参数的
完整流程代码如下:
前端发起callFunction到云端接收参数并响应,然后反馈前端,
前端接收,
完整流程代码如下:
```
js
```
js
// 客户端发起调用云函数hellocf,并传入data数据
// 客户端发起调用云函数hellocf,并传入data数据
...
@@ -228,7 +227,8 @@ exports.main = async (event, context) => {
...
@@ -228,7 +227,8 @@ exports.main = async (event, context) => {
那么客户端得到的res结构如下
那么客户端得到的res结构如下
```
json
```
json
{
{
"errCode"
:
0
"errCode"
:
0
,
"errMsg"
:
""
,
"header"
:
{
"header"
:
{
"access-control-expose-headers"
:
"Date,x-fc-request-id,x-fc-error-type,x-fc-code-checksum,x-fc-invocation-duration,x-fc-max-memory-usage,x-fc-log-result,x-fc-invocation-code-version"
"access-control-expose-headers"
:
"Date,x-fc-request-id,x-fc-error-type,x-fc-code-checksum,x-fc-invocation-duration,x-fc-max-memory-usage,x-fc-log-result,x-fc-invocation-code-version"
"content-disposition"
:
"attachment"
"content-disposition"
:
"attachment"
...
@@ -252,13 +252,23 @@ exports.main = async (event, context) => {
...
@@ -252,13 +252,23 @@ exports.main = async (event, context) => {
其中
`result`
是开发者云函数代码返回的数据,其余是云平台返回的。
其中
`result`
是开发者云函数代码返回的数据,其余是云平台返回的。
注意:HBuilderX本地运行云函数时只返回
`result`
,其他需要在云端运行云函数才会返回。
注意:HBuilderX本地运行云函数时,如果没有系统错误,则只返回
`result`
,其他需要在云端运行云函数才会返回。
-
errCode为0时,success也是true。
*
表示云函数在系统层面没有运行错误。可以正常返回result。前端callFunction会进入success回调
*
如果开发者的业务有报错,可以在 result 里返回 errCode 和 errMsg。
-
errCode不为0时,success为false。
*
表示云函数在系统层面报错了,比如联网失败、云函数超时、内存超限等错误。前端callFunction会进入fail回调
*
发生系统错误时 result 里无法正常返回业务错误。errCode不为0时,还会返回errMsg。
-
requestId是云函数的请求id,线上运行时,可以在uniCloud web控制台的云函数日志中查看运行日志。
-
header是云厂商的一些信息,阿里云和腾讯云不同,上面示例代码是阿里云的header。
**uniCloud响应体规范**
**uniCloud响应体规范**
为了方便统一拦截错误,推荐开发者使用
`uniCloud响应体规范`
,
[
详见
](
uniCloud/cf-functions.md?id=resformat
)
为了方便统一拦截错误,推荐开发者使用
[
uniCloud响应体规范
](
cf-functions.md?id=resformat
)
业务报错时,在 result 里返回 errCode 和 errMsg。如下:
如果按照uniCloud响应体规范,那么云函数代码应该修正为return信息补充errCode和errMsg。如下:
```
js
```
js
'
use strict
'
;
'
use strict
'
;
exports
.
main
=
async
(
event
,
context
)
=>
{
exports
.
main
=
async
(
event
,
context
)
=>
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录