HTTP触发器提供了函数专用的HTTP和HTTPS地址,您可以直接通过HTTP触发器提供的URL调用函数。本文将介绍内置运行时中使用HTTP触发器调用函数的方法。关于自定义运行时HTTP触发器调用函数的相关内容,请参见Web函数。
快速了解HTTP触发器
注意事项
在函数计算3.0版中,自定义运行时和自定义镜像运行环境的HTTP触发器行为与函数计算2.0版一致,但内置运行时函数的HTTP触发器与函数计算2.0版有较大的差异,详情请参见调用函数流程。
调用函数流程
对于内置运行时函数,当客户端调用函数URL时,函数计算会将请求映射到事件对象event,再将event传递给函数。函数执行结束后,返回的响应将映射到一个HTTP响应,函数计算会通过函数URL将HTTP响应发送回客户端。
请求结构体
请求结构体格式
请求结构体格式如下:
{
    "version": "v1",
    "rawPath": "/example",
    "body": "Hello FC!",
    "isBase64Encoded": false,
    "headers": {
        "header1": "value1",
        "header2": "value1,value2"
    },
    "queryParameters": {
        "parameter1": "value1",
        "parameter2": "value1,value2"
    },
    "requestContext": {
        "accountId": "123456*********",
        "domainName": "<http-trigger-id>.<region-id>.fcapp.run",
        "domainPrefix": "<http-trigger-id>",
        "http": {
            "method": "GET",
            "path": "/example",
            "protocol": "HTTP/1.1",
            "sourceIp": "11.11.11.**",
            "userAgent": "PostmanRuntime/7.32.3"
        },
        "requestId": "1-64f6cd87-*************",
        "time": "2023-09-05T06:41:11Z",
        "timeEpoch": "1693896071895"
    }
}请求结构体参数说明如下:
| 参数 | 说明 | 示例 | 
| version | 此事件的有效负载格式版本。目前版本为v1。 | v1 | 
| rawPath | 请求路径。例如,如果请求URL为 | /example | 
| body | 请求的正文。如果请求的内容类型为二进制,则正文为Base64编码。 | Hello FC! | 
| isBase64Encoded | 如果正文为二进制,并且为Base64编码,则为true,否则为false。 | false | 
| headers | 该参数为请求头的列表。以键值对的形式显示,当一个键存在多个值时,值之间使用逗号分隔。 当使用HTTP触发器调用内置运行时,FC3.0将HTTP请求转换成HTTP触发器的Event格式,将HTTP请求Header的键进行规范化,Header的键的首字母变为大写,详情参见Header键的首字母为什么变成了大写?。 | {"Header1": "value1", "Header2": "value1,value2"} | 
| queryParameters | 请求的查询参数。例如,如果请求URL为 | { "parameter1": "value1", "parameter2": "value1,value2" } | 
| requestContext | 一个包含有关请求的附加信息的对象,例如requestId、请求的时间以及通过授权的调用者身份。 | |
| requestContext.accountId | 函数拥有者的阿里云账户ID。 | 123456********* | 
| requestContext.domainName | 函数HTTP触发器的域名。 | <http-trigger-id>.<region-id>.fcapp.run | 
| requestContext.domainPrefix | 函数HTTP触发器的域前缀。 | <http-trigger-id> | 
| requestContext.http | 包含有关HTTP请求的详细信息。 | |
| requestContext.http.method | 此请求中使用的HTTP方法。有效值包括GET、POST、PUT、HEAD、OPTIONS、PATCH和DELETE。 | GET | 
| requestContext.http.path | 请求路径。例如,如果请求URL为 | /example | 
| requestContext.http.protocol | 请求的协议。 | HTTP/1.1 | 
| requestContext.http.sourceIp | 发出请求的即时TCP连接的源IP地址。该IP地址是直接建立连接的对端IP地址(RemoteAddr),即直接连接到服务器的客户端地址或最后一个代理的IP地址。 
 | 11.11.XX.XX | 
| requestContext.http.userAgent | 用户代理请求标头值。 | PostmanRuntime/7.32.3 | 
| requestContext.requestId | 调用请求的ID。可以使用此ID跟踪与函数相关的调用日志。 | 1-64f6cd87-************* | 
| requestContext.time | 请求的时间戳。 | 2023-09-05T06:41:11Z | 
| requestContext.timeEpoch | 请求的时间戳,用Unix时间表示。 | 1693896071895 | 
函数计算HTTP请求映射逻辑
函数计算会将HTTP请求映射成Event事件对象传给请求处理程序(Handler),映射逻辑如下:
- HTTP请求头映射为 - event结构中的- headers。
- HTTP请求参数映射为 - queryParameters。
- HTTP请求的上下文信息映射为 - requestContext。
- POST请求的请求体映射为 - body。
Base64编码机制
函数计算在将HTTP请求映射到事件对象event时,会根据请求头中的Content-Type类型判断是否对请求体进行Base64编码:
- 当请求头中的 - Content-Type表示文本类型时,不会对请求体进行Base64编码,- event结构中的- isBase64Encoded设置为- false。
- 否则,会对请求体进行Base64编码, - isBase64Encoded设置为- true。
以下为表示文本类型的Content-Type取值:
- text/* 
- application/json 
- application/ld+json 
- application/xhtml+xml 
- application/xml 
- application/atom+xml 
- application/javascript 
请求映射示例
GET请求
| HTTP请求 | Event事件结构 | 
|  |  | 
您可以在命令行使用以下命令,发送上述HTTP请求。请将https://example.cn-hangzhou.fcapp.run替换为您的HTTP触发器公网访问地址。
curl -v "https://example.cn-hangzhou.fcapp.run?parameter1=value1¶meter2=value2"POST请求
| HTTP请求 | Event事件结构 | 
|  |  | 
- 您可以在命令行使用以下命令,发送上述HTTP请求。请将 - https://example.cn-hangzhou.fcapp.run替换为您的HTTP触发器公网访问地址。- curl -v -H "Content-Type: application/json" -d '{"message": "Hello"}' "https://example.cn-hangzhou.fcapp.run"
- 如果您需要发送Base64编码的请求体,只需将请求头中的 - Content-Type设置为- application/x-www-form-urlencoded。
响应结构体
响应结构体格式
函数的响应结构体格式如下。当您的请求处理程序返回响应结构体时,函数计算会解析响应并将其转换为HTTP响应。
{
    "statusCode": 200,
    "headers": {
        "Content-Type": "application/json",
        "Custom-Header-1": "Custom Value"
    },
    "isBase64Encoded": false,
    "body": "{\"message\":\"Hello FC!\"}"
}函数计算响应解析逻辑
函数计算会解析响应并构造HTTP Response返回给客户端。
- 如果您的函数返回有效的JSON并且包含 - statusCode字段,函数计算解析逻辑如下:- statusCode:函数返回JSON中的- statusCode值。
- Content-Type:函数返回JSON中的- Content-Type值。如果JSON中没有- Content-Type,- Content-Type默认为- application/json。
- body:函数响应,函数返回JSON中的- body值。
- isBase64Encoded:函数返回JSON中的- isBase64Encoded值,如果JSON中没有- isBase64Encoded,则默认为false。
 
- 如果您的函数返回有效的JSON但是没有包含 - statusCode字段,或者返回的不是有效的JSON,函数计算会做出以下假设,构造响应结构体。- statusCode:默认为200。
- Content-Type:默认为- application/json。
- body:函数响应,即代码中return的数据。
- isBase64Encoded:默认为false。
 
函数计算会将函数响应结构体映射成HTTP响应返回给客户端,映射逻辑如下:
- statusCode映射为HTTP响应的状态码。
- headers映射为HTTP响应头。
- body映射为HTTP响应体,如果存在- isBase64Encoded且为true,则先将- body进行Base64解码,再映射到HTTP响应体。
响应映射示例
以下示例介绍了函数的输出如何映射到函数响应结构体,以及函数响应结构体如何映射到最终的HTTP响应。当客户端调用函数HTTP触发器时,就可以看到HTTP响应。
字符串响应的输出
| 函数输出 | 解析函数输出 | HTTP响应(客户端看到的内容) | 
| 
 |  |  | 
JSON响应的输出
| 函数输出 | 解析函数输出 | HTTP响应(客户端看到的内容) | 
| 
 |  |  | 
自定义响应的输出
| 函数输出 | 解析函数输出 | HTTP响应(客户端看到的内容) | 
|  |  |  | 
Base64解码机制
当函数输出为有效的JSON格式,且JSON中的isBase64Encoded字段为true时,函数计算会将JSON中的body字段进行Base64解码,再将解码后的数据通过HTTP响应体返回给客户端。
如果对body字段解码失败,函数计算不会报错,而是直接将原始的body字段的值返回给客户端。
响应头(HTTP Response Header)
使用HTTP触发器调用函数时,响应头中会包含函数计算默认添加的响应头X-Fc-Request-Id,这是此次请求的唯一标识。除了X-Fc-Request-Id,函数计算不会默认添加其他响应头。
您可以在代码中返回自定义的响应头,但不支持X-Fc-开头的响应头和以下函数计算保留的响应头:
- connection 
- content-length 
- date 
- keep-alive 
- server 
- content-disposition 
如果您在响应头中设置了这些保留字,函数计算会直接忽略您设置的响应头。
错误处理
当遇到函数错误时,通过API调用会返回具体的错误信息,HTTP返回码为200。比如Python的ModuleNotFound错误的响应如下:
{
    "errorMessage": "Unable to import module 'index'",
    "errorType": "ImportModuleError",
    "stackTrace": [
        "ModuleNotFoundError: No module named 'not_exist_module'"
    ]
}但使用HTTP 触发器调用时,函数计算会隐藏这些错误信息,直接返回 Internal Server Error,HTTP返回码为502。HTTP响应示例如下:
HTTP/1.1 502 Bad Gateway
Content-Disposition: attachment
Content-Type: application/json
X-Fc-Request-Id: 1-64f6df91-fe144d52e4fd27afe3d8dd6f
Date: Tue, 05 Sep 2023 07:58:09 GMT
Content-Length: 21
Internal Server Error此时,您可以通过请求返回的X-Fc-Request-Id在日志中查找具体的报错信息。
代码开发
在FC 3.0内置运行时中,编写代码时,请参考以下运行时的请求处理程序(Handler) 文档。