文档

配置HTTP触发器并使用HTTP触发

更新时间:
一键部署

函数计算支持HTTP触发器,配置HTTP触发器的函数可以通过HTTP请求被触发执行。函数对HTTP请求进行处理,并将处理结果返回给调用端。本文介绍如何在函数计算控制台配置HTTP触发器并使用HTTP请求触发。

前提条件

创建函数

步骤一:创建触发器

  1. 登录函数计算控制台,在左侧导航栏,单击函数

  2. 在顶部菜单栏,选择地域,然后在函数页面,单击目标函数。

  3. 在函数详情页面,选择配置页签,在左侧导航栏,单击触发器,然后单击创建触发器

  4. 在创建触发器面板,填写相关信息,然后单击确定

    配置项

    操作

    本文示例

    触发器类型

    选择HTTP 触发器

    HTTP 触发器

    名称

    填写自定义的触发器名称。

    http-trigger

    版本或别名

    默认值为LATEST,如果您需要创建其他版本或别名的触发器,需先在函数详情页的版本或别名下拉列表选择该版本。关于版本和别名的简介,请参见管理版本管理别名

    LATEST

    请求方法

    指定可以通过哪些方法触发器该HTTP触发器。

    GET, POST, PUT, DELETE

    禁用公网访问 URL

    默认选择,即允许公网域名访问该触发器。

    如果选择,创建的HTTP触发器将不提供默认的公网域名。此时,如果通过公网域名来调用函数,将会提示错误access denied due to function internet URL is disable。通过自定义域名的访问,则不受影响。

    认证方式

    选择函数计算对HTTP请求的认证方式。取值说明如下:

    • 无需认证:无需对HTTP请求进行身份认证,支持匿名访问,任何人可发起HTTP请求调用您的函数。

    • 签名认证:需要对HTTP请求进行身份认证。关于签名认证的示例代码,请参见通过签名访问HTTP触发器地址

    • JWT 认证:需要对HTTP请求进行JWT认证。更多信息,请参见为HTTP触发器配置JWT认证鉴权

    无需认证

    创建完成后,您可以根据情况对HTTP触发器的配置项进行修改,包括版本或别名请求方法禁用公网访问 URL认证方式

步骤二:编写并部署代码

完成创建HTTP触发器后,您可以开始编写函数代码。

在函数详情页面,单击代码页签,在代码编辑器中编写代码,然后单击部署代码关于示例代码,请参见函数计算文档操作指南 > 代码开发中不同运行时的请求处理程序文档。

步骤三:测试函数

方式一:使用控制台测试函数

函数详情页面,单击代码页签。

  • 同步调用

    单击测试函数

  • 异步调用

    单击测试函数右侧的down图标,选择异步调用,然后单击测试函数

执行完成后,在代码页签,您可以查看执行结果。

方式二:使用cURL测试函数

  • 同步调用

    在命令行执行如下命令,执行完成后会返回执行结果。

    curl -v https://http-***.cn-shenzhen.fcapp.run/$path
  • 异步调用

    在命令行执行如下命令,执行完成后会返回函数计算接收请求的结果。其中状态码202表示请求成功,其余表示请求出现错误,关于错误码的解释,请参见常见问题(错误排查)

    curl -v -H "X-Fc-Invocation-Type: Async" https://http-***.cn-shenzhen.fcapp.run/$path

(可选)使用API网关保护函数

默认情况下,函数计算不会对HTTP请求进行身份验证,支持匿名访问函数,即任何人都可以发送HTTP请求调用您的函数。为防止非法用户访问您的函数,引起不必要的资源浪费或安全隐患,您可以开启身份认证的同时将HTTP函数与API网关进行对接,利用API网关的IP访问控制插件、JWT认证插件或BasicAuth插件等保护您的HTTP函数。

  1. 函数计算控制台找到目标函数,在函数详情页面单击配置页签,在左侧导航栏选择触发器,然后单击编辑

  2. 在编辑触发器面板,禁用公网访问 URL选择为

  3. 登录API网关控制台,切换至HTTP函数所在地域。

  4. 创建分组。具体操作,请参见创建分组

  5. 将您的域名通过CNAME方式解析到API网关提供的二级域名上。具体操作,请参见CNAME绑定域名

  6. 创建API。

    主要配置项设置如下,其余配置项下的设置选择默认值或者根据实际情况填写即可。更多信息,请参见创建 API

    • 安全认证:选择无认证,后续会使用插件进行认证。

    • 请求Path:填写根目录/,然后选中匹配所有子路径

    • HTTP Method:选择ANY

    • 入参请求模式:选择入参透传

    • 后端服务类型:选择函数计算

    • 产品版本:选择函数计算3.0

    • 函数类型:选择HTTP函数

    • 触发器路径:填写函数计算的HTTP触发器的内网访问地址

    • ContentType:选择透传客户端ContentType头

  7. 发布API。单击已创建的API右侧操作列的发布,选择线上环境,然后单击发布

  8. 创建一个类型为后端签名的插件,keysecret分别配置为您的阿里云账号的AccessKey IDAccessKey Secret。然后绑定您刚才创建的API。具体操作,请参见插件概述

完成以上步骤后,您可以通过自己的域名访问HTTP函数。您还可以创建以下插件,并将其绑定到您的API,保护您的HTTP函数。

错误排查

错误主要分为以下两种。

  • 请求错误是指发送的Request不符合标准,在Response里报错状态码为4xx。

  • 函数错误即编写的函数有问题,会报5xx状态码。

下表描述请求错误和函数错误可能出现的场景,以便您迅速排查问题。

错误类型

HTTP状态码

原因分析

是否计费

请求错误

400

您的请求超过Request限制项的限制。更多信息,请参见HTTP触发器概述

400

调用需要身份认证的函数的Request没有传入Date信息或Authorization信息。

403

调用需要身份认证的函数的Request的签名错误,即Authorization不正确。由于Date参与签名计算,且超过15 min,签名失效,一种常见的原因是使用需要访问认证的HTTP触发器,Request header中发送的Date据当前时间超过15 min,导致签名失效。

403

您的Request请求使用HTTP触发器中未配置的请求方法。例如,HTTP触发器中的请求方法只配置GET方法,却发送POST方法的HTTP请求。

404

向没有设置HTTP触发器的函数发送HTTP请求。

用户流控

429

用户被流控,可减小并发量或者联系函数计算开发团队提高并发度。

函数错误

502

函数的返回值超过Response限制项的限制。更多信息,请参见HTTP触发器概述

502

函数代码有语法错误或者异常。

502

向未使用HTTP入口函数的函数发送HTTP请求。

系统错误

500

函数计算系统错误,可重试解决。

系统流控

503

函数计算系统流控。可用指数退避方式重试。

如果问题还未能解决,请加入钉钉用户群(钉钉群号:11721331),联系函数计算工程师及时沟通处理。

  • 本页导读 (1)
文档反馈