内置变量
API7 企业版中的内置变量是可以在配置中直接引用的预定义变量。它们通常用于插件配置、路由匹配和日志自定义。
API7 企业版支持两种类型的内置变量:
- NGINX 变量
- APISIX 变量
这些变量按照特定的顺序进行求值。
NGINX 变量
NGINX 提供了一组变量,可用于访问各种特定的请求信息。
一些常用的变量包括:
upstream_addrremote_addrrequest_uriserver_nameurihttp_user_agent
有关更多信息,请参阅 NGINX 变量的完整列表。
APISIX 变量
除了 NGINX 变量 之外,APISIX 还提供了各种内置变量:
| 变量名称 | 描述 |
|---|---|
post_arg_* | 内容类型为 application/x-www-form-urlencoded 时的 HTTP POST 表单数据。星号将替换为 POST 表单数据的实际名称。 |
post_arg.* | 内容类型为 application/json、application/x-www-form-urlencoded 或 multipart/form-data 时的 HTTP POST 请求体参数。星号替换为 POST 参数的实际名称。支持类似 JSON path 的选择器,如 post_arg.model.version 和 post_arg.messages[*].content[*].type。 |
arg_* | URL 查询字符串。星号替换为实际的查询参数名称。 |
http_* | HTTP 请求头。星号替换为实际的请求头名称。 |
cookie_* | 请求 Cookie。星号替换为实际的 Cookie 名称。 |
balancer_ip | 上游服务器 IP。 |
balancer_port | 上游服务器端口。 |
consumer_name | 消费者用户名。 |
consumer_group_id | 消费者组 ID。 |
graphql_name | GraphQL 操作名称。 |
graphql_operation | GraphQL 操作类型。 |
graphql_root_fields | GraphQL 根字段。 |
route_id | 路由 ID。 |
route_name | 路由名称。 |
service_id | 服务 ID。 |
service_name | 服务名称。 |
resp_body | HTTP 响应体。 |
mqtt_client_id | MQTT 协议中的客户端 ID。 |
redis_cmd_line | Redis 命令。 |
rpc_time | RPC 请求往返时间。 |
external_user.* | 外部用户信息(从 API7 企业版 3.8.19 开始提供)。该变量由 openid-connect 插件和开发者 OAuth 凭证注入,可供其他插件使用。例如,当 key 设置为 ${external_user.preferred_username} 时,limit-count-advanced 可以按用户名执行速率限制。 |
评估顺序
API7 企业版按以下给定顺序评估变量:
- APISIX 变量
- NGINX 变量
如果在自定义变量中成功获取到变量值,API7 企业版将不再继续在 APISIX 变量或 NGINX 变量中查找。
换句话说,自定义变量将覆盖在 APISIX 变量或 NGINX 变量中定义的同名变量,以更好地满足你特定用例的需求。