查询API信息
功能介绍
查询API信息。
调用方法
请参见如何调用API。
URI
GET /v1/{project_id}/service/apis/{api_id}
参数 |
是否必选 |
参数类型 |
描述 |
---|---|---|---|
project_id |
是 |
String |
项目ID,获取方法请参见项目ID和账号ID。 |
api_id |
是 |
String |
API ID。 |
请求参数
参数 |
是否必选 |
参数类型 |
描述 |
---|---|---|---|
X-Auth-Token |
是 |
String |
用户Token,使用Token认证时必选。通过调用IAM服务的“获取用户Token”接口获取响应消息头中X-Subject-Token的值。 |
workspace |
是 |
String |
工作空间ID,获取方法请参见实例ID和工作空间ID。 |
Dlm-Type |
否 |
String |
数据服务的版本类型,指定SHARED共享版或EXCLUSIVE专享版。 |
Content-Type |
是 |
String |
消息体的类型(格式),有Body体的情况下必选,没有Body体无需填写。如果请求消息体中含有中文字符,则需要通过charset=utf8指定中文字符集,例如取值为:application/json;charset=utf8。 |
响应参数
状态码: 200
参数 |
参数类型 |
描述 |
---|---|---|
id |
String |
API的ID。 |
name |
String |
API名称。 |
group_id |
String |
API所属分组的ID(共享版)。 |
description |
String |
API描述。 |
protocol |
String |
API请求协议类型。 枚举值:
|
publish_type |
String |
发布类型(已弃用)。 枚举值:
|
log_flag |
Boolean |
是否开启日志记录。 |
path |
String |
API的访问路径。 |
host |
String |
共享版域名。 |
hosts |
InstanceHostDTO object |
专享版域名。 |
request_type |
String |
请求类型。 枚举值:
|
create_user |
String |
API创建者。 |
create_time |
Long |
创建时间。 |
update_time |
Long |
更新时间。 |
manager |
String |
API审核人名称。 |
status |
String |
API的状态(共享版)。 枚举值:
|
type |
String |
API类型。 枚举值:
|
debug_status |
String |
API调试状态(共享版)。 枚举值:
|
publish_messages |
Array of ApiPublishDTO objects |
发布信息列表(专享版)。 |
request_paras |
Array of RequestPara objects |
API请求参数。 |
datasource_config |
DatasourceConfig object |
数据源配置。 |
backend_config |
BackendConfig object |
后端配置。 |
参数 |
参数类型 |
描述 |
---|---|---|
instance_id |
String |
集群ID编号。 |
instance_name |
String |
集群名。 |
intranet_host |
String |
内网地址。 |
external_host |
String |
外网地址。 |
domains |
Array of strings |
网关域名。 |
参数 |
参数类型 |
描述 |
---|---|---|
id |
String |
发布编号。 |
api_id |
String |
API编号。 |
instance_id |
String |
集群ID编号。 |
instance_name |
String |
集群名称。 |
api_status |
String |
API的状态。 枚举值:
|
api_debug |
String |
API调试状态。 枚举值:
|
参数 |
参数类型 |
描述 |
---|---|---|
name |
String |
参数名。 |
position |
String |
参数的位置。 枚举值:
|
type |
String |
常量参数类型。 枚举值:
|
description |
String |
参数的描述。 |
necessary |
Boolean |
参数是否必填。 |
example_value |
String |
示例值。 |
default_value |
String |
默认值。 |
support_null |
Boolean |
支持NULL值。 |
参数 |
参数类型 |
描述 |
---|---|---|
type |
String |
数据源的类型。 枚举值:
|
connection_name |
String |
数据连接名称。 |
connection_id |
String |
数据连接ID。 |
database |
String |
数据库名。 |
datatable |
String |
数据表名称。 |
table_id |
String |
数据表ID。 |
queue |
String |
DLI的队列名称。 |
access_mode |
String |
获取数据的模式。 枚举值:
|
access_type |
String |
取数方式(已弃用)。 枚举值:
|
pagination |
String |
分页方式。 枚举值:
|
sql |
String |
脚本模式下的SQL语句。 |
backend_paras |
Array of ApiRequestPara objects |
API后端参数。 |
response_paras |
Array of ApiResponsePara objects |
配置类API返回参数。 |
order_paras |
Array of DatasourceOrderPara objects |
排序参数。 |
total_size_sql |
String |
总条数计算脚本SQL。 |
参数 |
参数类型 |
描述 |
---|---|---|
name |
String |
参数名称。 |
mapping |
String |
映射字段。 |
condition |
String |
操作符。 枚举值:
|
参数 |
参数类型 |
描述 |
---|---|---|
name |
String |
参数名。 |
field |
String |
绑定的表字段。 |
type |
String |
常量参数类型。 枚举值:
|
description |
String |
参数描述。 |
example_value |
String |
参数示例值。 |
参数 |
参数类型 |
描述 |
---|---|---|
name |
String |
排序参数名称。 |
field |
String |
对应的参数字段。 |
optional |
Boolean |
是否可选。 |
sort |
String |
排序方式。 枚举值:
|
order |
Integer |
排序参数顺序。 |
description |
String |
排序参数描述信息。 |
参数 |
参数类型 |
描述 |
---|---|---|
type |
String |
请求类型。
|
protocol |
String |
API请求协议类型。
|
host |
String |
后端HOST。 |
timeout |
Integer |
后端超时时间。 |
path |
String |
后端请求PATH。 |
backend_paras |
Array of BackendRequestPara objects |
API后端参数。 |
constant_paras |
Array of BackendConstant objects |
后端常量参数。 |
参数 |
参数类型 |
描述 |
---|---|---|
name |
String |
API请求参数名称。 |
position |
String |
参数的位置。 枚举值:
|
backend_para_name |
String |
对应的后端参数。 |
参数 |
参数类型 |
描述 |
---|---|---|
name |
String |
常量参数名。 |
type |
String |
常量参数类型。 枚举值:
|
position |
String |
参数的位置。 枚举值:
|
description |
String |
常量参数描述。 |
value |
String |
常量参数值。 |
状态码: 400
参数 |
参数类型 |
描述 |
---|---|---|
error_code |
String |
错误码。 |
error_msg |
String |
错误描述。 |
请求示例
查询Id为10e3a4b67f59a9efe64e6bb31859221f的API信息。
/v1/0833a5737480d53b2f250010d01a7b88/service/apis/10e3a4b67f59a9efe64e6bb31859221f
响应示例
状态码: 200
Success。
{ "id" : "6b9e682fd6d0ef7c0f674701adb20762", "name" : "testApi", "group_id" : "677942eeca42b85d82fcef909d8345f4", "description" : "", "protocol" : "PROTOCOL_TYPE_HTTP", "publish_type" : "PUBLISH_TYPE_PUBLIC", "log_flag" : true, "path" : "/testApi/{a}", "host" : null, "hosts" : null, "request_type" : "REQUEST_TYPE_POST", "create_time" : 1579162215000, "update_time" : 1579162691000, "manager" : "admin", "status" : "API_STATUS_CREATED", "type" : "API_SPECIFIC_TYPE_CONFIGURATION", "debug_status" : "API_DEBUG_WAITING", "request_paras" : [ { "name" : "a", "position" : "REQUEST_PARAMETER_POSITION_PATH", "type" : "REQUEST_PARAMETER_TYPE_NUMBER", "description" : "", "necessary" : false, "example_value" : "", "default_value" : "" }, { "name" : "b", "position" : "REQUEST_PARAMETER_POSITION_HEADER", "type" : "REQUEST_PARAMETER_TYPE_NUMBER", "description" : "", "necessary" : false, "example_value" : "", "default_value" : "" }, { "name" : "c", "position" : "REQUEST_PARAMETER_POSITION_QUERY", "type" : "REQUEST_PARAMETER_TYPE_NUMBER", "description" : "", "necessary" : false, "example_value" : "", "default_value" : "" } ], "datasource_config" : null, "backend_config" : { "type" : "REQUEST_TYPE_GET", "protocol" : "PROTOCOL_TYPE_HTTP", "timeout" : "100", "host" : "www.baidu.com", "path" : "/testApi/{d}/{g}", "backend_paras" : [ { "name" : "a", "position" : "REQUEST_PARAMETER_POSITION_PATH", "backend_para_name" : "d" }, { "name" : "b", "position" : "REQUEST_PARAMETER_POSITION_QUERY", "backend_para_name" : "e" }, { "name" : "c", "position" : "REQUEST_PARAMETER_POSITION_HEADER", "backend_para_name" : "f" } ], "constant_paras" : [ { "name" : "g", "type" : "REQUEST_PARAMETER_TYPE_NUMBER", "position" : "REQUEST_PARAMETER_POSITION_PATH", "description" : "", "value" : "1" }, { "name" : "h", "type" : "REQUEST_PARAMETER_TYPE_NUMBER", "position" : "REQUEST_PARAMETER_POSITION_QUERY", "description" : "", "value" : "1" }, { "name" : "j", "type" : "REQUEST_PARAMETER_TYPE_NUMBER", "position" : "REQUEST_PARAMETER_POSITION_HEADER", "description" : "", "value" : "1" } ] } }
SDK代码示例
SDK代码示例如下。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 |
package com.huaweicloud.sdk.test; import com.huaweicloud.sdk.core.auth.ICredential; import com.huaweicloud.sdk.core.auth.BasicCredentials; import com.huaweicloud.sdk.core.exception.ConnectionException; import com.huaweicloud.sdk.core.exception.RequestTimeoutException; import com.huaweicloud.sdk.core.exception.ServiceResponseException; import com.huaweicloud.sdk.dataartsstudio.v1.region.DataArtsStudioRegion; import com.huaweicloud.sdk.dataartsstudio.v1.*; import com.huaweicloud.sdk.dataartsstudio.v1.model.*; public class ShowApiSolution { public static void main(String[] args) { // The AK and SK used for authentication are hard-coded or stored in plaintext, which has great security risks. It is recommended that the AK and SK be stored in ciphertext in configuration files or environment variables and decrypted during use to ensure security. // In this example, AK and SK are stored in environment variables for authentication. Before running this example, set environment variables CLOUD_SDK_AK and CLOUD_SDK_SK in the local environment String ak = System.getenv("CLOUD_SDK_AK"); String sk = System.getenv("CLOUD_SDK_SK"); String projectId = "{project_id}"; ICredential auth = new BasicCredentials() .withProjectId(projectId) .withAk(ak) .withSk(sk); DataArtsStudioClient client = DataArtsStudioClient.newBuilder() .withCredential(auth) .withRegion(DataArtsStudioRegion.valueOf("<YOUR REGION>")) .build(); ShowApiRequest request = new ShowApiRequest(); request.withApiId("{api_id}"); try { ShowApiResponse response = client.showApi(request); System.out.println(response.toString()); } catch (ConnectionException e) { e.printStackTrace(); } catch (RequestTimeoutException e) { e.printStackTrace(); } catch (ServiceResponseException e) { e.printStackTrace(); System.out.println(e.getHttpStatusCode()); System.out.println(e.getRequestId()); System.out.println(e.getErrorCode()); System.out.println(e.getErrorMsg()); } } } |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 |
# coding: utf-8 import os from huaweicloudsdkcore.auth.credentials import BasicCredentials from huaweicloudsdkdataartsstudio.v1.region.dataartsstudio_region import DataArtsStudioRegion from huaweicloudsdkcore.exceptions import exceptions from huaweicloudsdkdataartsstudio.v1 import * if __name__ == "__main__": # The AK and SK used for authentication are hard-coded or stored in plaintext, which has great security risks. It is recommended that the AK and SK be stored in ciphertext in configuration files or environment variables and decrypted during use to ensure security. # In this example, AK and SK are stored in environment variables for authentication. Before running this example, set environment variables CLOUD_SDK_AK and CLOUD_SDK_SK in the local environment ak = os.environ["CLOUD_SDK_AK"] sk = os.environ["CLOUD_SDK_SK"] projectId = "{project_id}" credentials = BasicCredentials(ak, sk, projectId) client = DataArtsStudioClient.new_builder() \ .with_credentials(credentials) \ .with_region(DataArtsStudioRegion.value_of("<YOUR REGION>")) \ .build() try: request = ShowApiRequest() request.api_id = "{api_id}" response = client.show_api(request) print(response) except exceptions.ClientRequestException as e: print(e.status_code) print(e.request_id) print(e.error_code) print(e.error_msg) |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 |
package main import ( "fmt" "github.com/huaweicloud/huaweicloud-sdk-go-v3/core/auth/basic" dataartsstudio "github.com/huaweicloud/huaweicloud-sdk-go-v3/services/dataartsstudio/v1" "github.com/huaweicloud/huaweicloud-sdk-go-v3/services/dataartsstudio/v1/model" region "github.com/huaweicloud/huaweicloud-sdk-go-v3/services/dataartsstudio/v1/region" ) func main() { // The AK and SK used for authentication are hard-coded or stored in plaintext, which has great security risks. It is recommended that the AK and SK be stored in ciphertext in configuration files or environment variables and decrypted during use to ensure security. // In this example, AK and SK are stored in environment variables for authentication. Before running this example, set environment variables CLOUD_SDK_AK and CLOUD_SDK_SK in the local environment ak := os.Getenv("CLOUD_SDK_AK") sk := os.Getenv("CLOUD_SDK_SK") projectId := "{project_id}" auth := basic.NewCredentialsBuilder(). WithAk(ak). WithSk(sk). WithProjectId(projectId). Build() client := dataartsstudio.NewDataArtsStudioClient( dataartsstudio.DataArtsStudioClientBuilder(). WithRegion(region.ValueOf("<YOUR REGION>")). WithCredential(auth). Build()) request := &model.ShowApiRequest{} request.ApiId = "{api_id}" response, err := client.ShowApi(request) if err == nil { fmt.Printf("%+v\n", response) } else { fmt.Println(err) } } |
更多编程语言的SDK代码示例,请参见API Explorer的代码示例页签,可生成自动对应的SDK代码示例。
状态码
状态码 |
描述 |
---|---|
200 |
Success。 |
400 |
BadRequest。 |