搜索可见性数据接口 - LLM Markdown

# 搜索可见性数据接口

> 来源页面: https://www.gugudata.com/api/details/search-visibility

## 概览

- API 标识: `search-visibility`
- 分类: 搜索/可见性
- 描述: 提供采样搜索可见性观测,按关键词和搜索来源返回品牌域名覆盖、排名位置、竞品对比等结果。
- 标签: 采样搜索可见性观测 / JSON API
- 短标签: 搜索可见性 / SEO
- 详情页: https://www.gugudata.com/api/details/search-visibility
- LLM Markdown: https://www.gugudata.com/api/details/search-visibility/llm.md
- 数据预览: https://www.gugudata.com/preview/search-visibility
- 购买开通: https://www.gugudata.com/order/search-visibility
- APP KEY 管理: https://www.gugudata.com/portal/
- 订单与续费: https://www.gugudata.com/portal/orders

## 给大模型的接入指令

如果你正在帮助用户接入这个 API,请优先使用本文档中的接口地址、请求方式、请求参数、返回参数、状态码、cURL 示例和预览数据生成代码或排查问题。

- 接入目标: 调用 `搜索可见性数据接口`,不要臆造未在文档中出现的参数或返回字段。
- AppKey 获取: 用户登录咕咕数据开发者中心后,在 `APP KEY 管理` 页面复制对应产品的 AppKey。
- AppKey 替换: 示例中的 `YOUR_APPKEY`、`APPKEY`、`{{YOUR_APPKEY}}`、`{{appkey}}`、`{{appKey}}` 都应替换为用户自己的 AppKey。
- AppKey 传递: 推荐使用 `X-GUGUDATA-APPKEY` 或 `X-API-Key` 请求头;OpenAI 兼容客户端可使用 `Authorization: Bearer <AppKey>`;历史示例中的 query 参数 `appkey` 继续有效。
- 开通与续费: 未开通时引导用户访问购买开通页;已开通或需要续费时,引导用户进入开发者中心或订单与续费页。
- 错误处理: HTTP 状态码代表传输层结果,响应体内的业务状态码代表接口业务结果,代码中应分别处理。
- 生产建议: AppKey 应保存在服务端环境变量或密钥配置中,由服务端统一发起请求,不要写入网页、App 客户端或公开仓库。

关键链接:

- 接口详情页: https://www.gugudata.com/api/details/search-visibility
- LLM Markdown: https://www.gugudata.com/api/details/search-visibility/llm.md
- 数据预览: https://www.gugudata.com/preview/search-visibility
- 购买开通页: https://www.gugudata.com/order/search-visibility
- 开发者中心 APP KEY 管理: https://www.gugudata.com/portal/
- 订单与续费: https://www.gugudata.com/portal/orders

## API 功能

- 按关键词和搜索来源观测品牌域名覆盖情况;
- 返回排名位置、可见性评分和竞品对比结果;
- 支持报告、观测任务和结果的分页查询;
- 接口调用状态与状态监控: https://www.gugudata.com/status

## API 文档

- 接口地址: `https://api.gugudata.com/v1/searchVisibilityReports`
- 返回格式: `application/json; charset=utf-8`
- 请求方式: `POST`
- 请求协议: `HTTPS`
- 请求示例: `https://api.gugudata.com/v1/searchVisibilityReports?appkey=APPKEY`
- 接口测试: https://api.gugudata.com/v1/searchVisibilityReports
- Apifox: https://doc.gugudata.com/
- Postman: https://www.postman.com/gugudata/gugudata-official/collection/1163860-ee114343-4622-4a54-a39b-994173c27dac/?action=share&creator=1163860&active-environment=1163860-a95b31ef-324f-43db-b2fc-faa41f45bd35
- OpenAPI: https://www.gugudata.com/openapi/gugudata.openapi.3.1.json

## 鉴权方式

接口支持以下 AppKey 传递方式,任选一种即可;已有请求示例、Postman 集合和历史代码仍可继续使用原来的 `appkey` 参数方式。

| 位置 | 写法 | 说明 |
| --- | --- | --- |
| HTTP Header | `X-GUGUDATA-APPKEY: YOUR_APPKEY` | 推荐方式,适合服务端接入和统一封装。 |
| HTTP Header | `X-API-Key: YOUR_APPKEY` | 通用 API Key Header,便于和常见 API 客户端集成。 |
| HTTP Header | `Authorization: Bearer YOUR_APPKEY` | 适合 OpenAI 兼容接口或 Bearer Token 风格客户端。 |
| Query 参数 | `?appkey=YOUR_APPKEY` | 兼容现有示例、Postman 集合、浏览器调试和历史代码。 |

> 部分历史 POST 接口仍兼容表单或 JSON body 中的 `appkey`;新接入建议优先使用 Header 或 Query 参数。

## 请求参数

| 参数名 | 参数类型 | 是否必须 | 默认值 | 备注 |
| --- | --- | --- | --- | --- |
| appkey | string | 是 | APPKEY | 付费后获取的 APPKEY。文档示例默认通过 Query 参数 appkey 传递;历史 Form 或 JSON body 中的 appkey 仍兼容。 |
| brand | string | 是 |  | 品牌或产品名称。 |
| domain | string | 是 |  | 需要观测的主域名。 |
| queries | array | 是 |  | 需要观测的搜索关键词列表。 |
| sources | array | 是 |  | 搜索来源,支持 google_web、bing_web、baidu_web。 |
| displayName | string | 否 |  | 报告显示名称。 |
| aliases | array | 否 |  | 品牌别名列表。 |
| competitors | array | 否 |  | 竞品域名定义列表。 |
| locale | string | 否 |  | 语言区域提示。 |
| region | string | 否 |  | 地域提示。 |
| maxRank | integer | 否 | 20 | 观测排名深度,支持 10、20、50。 |
| includeRawResponse | boolean | 否 | false | 是否保留原始响应引用。 |

## 返回参数

| 参数名 | 参数类型 | 备注 |
| --- | --- | --- |
| reportId | string | 报告 ID。 |
| runId | string | 观测任务 ID。 |
| status | string | 任务或资源状态。 |
| visibilityScore | number | 搜索可见性评分。 |
| checkedAt | string | 观测时间。 |

## 相关接口

### 获取搜索可见性报告

- 请求方式: `GET`
- 资源路径: `/v1/searchVisibilityReports/{reportId}`
- 接口地址: `https://api.gugudata.com/v1/searchVisibilityReports/{reportId}`
- 描述: 读取指定搜索可见性报告。

#### 请求参数

| 参数名 | 参数类型 | 是否必须 | 备注 |
| --- | --- | --- | --- |
| reportId | string | 是 | 报告 ID。 |

#### 请求示例

```json
[]
```

#### 返回参数

| 参数名 | 参数类型 | 备注 |
| --- | --- | --- |
| reportId | string | 报告 ID。 |
| runId | string | 观测任务 ID。 |
| status | string | 任务或资源状态。 |
| visibilityScore | number | 搜索可见性评分。 |
| checkedAt | string | 观测时间。 |

#### 响应示例

```json
[]
```

### 搜索可见性报告列表

- 请求方式: `GET`
- 资源路径: `/v1/searchVisibilityReports`
- 接口地址: `https://api.gugudata.com/v1/searchVisibilityReports`
- 描述: 分页读取搜索可见性报告。

#### 请求参数

| 参数名 | 参数类型 | 是否必须 | 备注 |
| --- | --- | --- | --- |
| pageSize | integer | 否 | 每页返回数量。 |
| pageToken | string | 否 | 分页令牌。 |
| filter | string | 否 | 过滤表达式。 |
| orderBy | string | 否 | 排序表达式。 |

#### 请求示例

```json
[]
```

#### 返回参数

| 参数名 | 参数类型 | 备注 |
| --- | --- | --- |
| reportId | string | 报告 ID。 |
| runId | string | 观测任务 ID。 |
| status | string | 任务或资源状态。 |
| visibilityScore | number | 搜索可见性评分。 |
| checkedAt | string | 观测时间。 |

#### 响应示例

```json
[]
```

### 创建搜索可见性观测任务

- 请求方式: `POST`
- 资源路径: `/v1/searchVisibilityReports/{reportId}/runs`
- 接口地址: `https://api.gugudata.com/v1/searchVisibilityReports/{reportId}/runs`
- 描述: 为报告创建一次新的采样观测。

#### 请求参数

| 参数名 | 参数类型 | 是否必须 | 备注 |
| --- | --- | --- | --- |
| reportId | string | 是 | 报告 ID。 |
| forceRefresh | boolean | 否 | 是否跳过缓存重新观测。 |
| includeRawResponse | boolean | 否 | 是否保留原始响应引用。 |

#### 请求示例

```json
[]
```

#### 返回参数

| 参数名 | 参数类型 | 备注 |
| --- | --- | --- |
| reportId | string | 报告 ID。 |
| runId | string | 观测任务 ID。 |
| status | string | 任务或资源状态。 |
| visibilityScore | number | 搜索可见性评分。 |
| checkedAt | string | 观测时间。 |

#### 响应示例

```json
[]
```

### 搜索可见性观测任务列表

- 请求方式: `GET`
- 资源路径: `/v1/searchVisibilityReports/{reportId}/runs`
- 接口地址: `https://api.gugudata.com/v1/searchVisibilityReports/{reportId}/runs`
- 描述: 分页读取报告下的观测任务。

#### 请求参数

| 参数名 | 参数类型 | 是否必须 | 备注 |
| --- | --- | --- | --- |
| reportId | string | 是 | 报告 ID。 |
| pageSize | integer | 否 | 每页返回数量。 |
| pageToken | string | 否 | 分页令牌。 |
| filter | string | 否 | 过滤表达式。 |
| orderBy | string | 否 | 排序表达式。 |

#### 请求示例

```json
[]
```

#### 返回参数

| 参数名 | 参数类型 | 备注 |
| --- | --- | --- |
| reportId | string | 报告 ID。 |
| runId | string | 观测任务 ID。 |
| status | string | 任务或资源状态。 |
| visibilityScore | number | 搜索可见性评分。 |
| checkedAt | string | 观测时间。 |

#### 响应示例

```json
[]
```

### 获取搜索可见性观测任务

- 请求方式: `GET`
- 资源路径: `/v1/searchVisibilityRuns/{runId}`
- 接口地址: `https://api.gugudata.com/v1/searchVisibilityRuns/{runId}`
- 描述: 读取指定观测任务。

#### 请求参数

| 参数名 | 参数类型 | 是否必须 | 备注 |
| --- | --- | --- | --- |
| runId | string | 是 | 观测任务 ID。 |

#### 请求示例

```json
[]
```

#### 返回参数

| 参数名 | 参数类型 | 备注 |
| --- | --- | --- |
| reportId | string | 报告 ID。 |
| runId | string | 观测任务 ID。 |
| status | string | 任务或资源状态。 |
| visibilityScore | number | 搜索可见性评分。 |
| checkedAt | string | 观测时间。 |

#### 响应示例

```json
[]
```

### 搜索可见性观测结果列表

- 请求方式: `GET`
- 资源路径: `/v1/searchVisibilityRuns/{runId}/results`
- 接口地址: `https://api.gugudata.com/v1/searchVisibilityRuns/{runId}/results`
- 描述: 分页读取观测任务结果。

#### 请求参数

| 参数名 | 参数类型 | 是否必须 | 备注 |
| --- | --- | --- | --- |
| runId | string | 是 | 观测任务 ID。 |
| pageSize | integer | 否 | 每页返回数量。 |
| pageToken | string | 否 | 分页令牌。 |
| filter | string | 否 | 过滤表达式。 |
| orderBy | string | 否 | 排序表达式。 |

#### 请求示例

```json
[]
```

#### 返回参数

| 参数名 | 参数类型 | 备注 |
| --- | --- | --- |
| reportId | string | 报告 ID。 |
| runId | string | 观测任务 ID。 |
| status | string | 任务或资源状态。 |
| visibilityScore | number | 搜索可见性评分。 |
| checkedAt | string | 观测时间。 |

#### 响应示例

```json
[]
```

### 获取搜索可见性观测结果

- 请求方式: `GET`
- 资源路径: `/v1/searchVisibilityResults/{resultId}`
- 接口地址: `https://api.gugudata.com/v1/searchVisibilityResults/{resultId}`
- 描述: 读取指定观测结果。

#### 请求参数

| 参数名 | 参数类型 | 是否必须 | 备注 |
| --- | --- | --- | --- |
| resultId | string | 是 | 观测结果 ID。 |

#### 请求示例

```json
[]
```

#### 返回参数

| 参数名 | 参数类型 | 备注 |
| --- | --- | --- |
| reportId | string | 报告 ID。 |
| runId | string | 观测任务 ID。 |
| status | string | 任务或资源状态。 |
| visibilityScore | number | 搜索可见性评分。 |
| checkedAt | string | 观测时间。 |

#### 响应示例

```json
[]
```

## 接口常见 HTTP 响应状态码

> 以下为接口调用中常见的 HTTP 传输层状态码,不等同于响应体内的业务状态码;完整状态码注册表以 IANA HTTP Status Code Registry 为准。

| 状态码 | 状态码解释 | 备注 |
| --- | --- | --- |
| 200 | 请求成功 | HTTP 请求已成功处理;业务状态请结合响应体中的自定义业务码判断。 |
| 201 | 资源已创建 | 创建类接口请求成功,并已生成对应资源。 |
| 202 | 请求已接受 | 请求已被接受处理,结果可能异步完成。 |
| 204 | 无响应内容 | 请求成功但响应体为空,适用于无需返回数据的操作。 |
| 304 | 资源未变更 | 配合缓存或条件请求使用,表示可继续使用本地缓存。 |
| 400 | 请求参数错误 | 请求参数缺失、格式错误或参数组合不合法。 |
| 401 | 认证失败 | 缺少、无效或未通过认证的访问凭证(如 AppKey)。 |
| 403 | 无权限访问 | 订单到期、权限不足或接口额度不可用。 |
| 404 | 资源不存在 | 请求路径不存在。 |
| 405 | 请求方法不允许 | 当前路径不支持该 HTTP 方法。 |
| 408 | 请求超时 | 客户端请求在服务端等待时间内未完成,可稍后重试。 |
| 409 | 请求冲突 | 请求与当前资源状态冲突,调整参数或业务状态后重试。 |
| 413 | 请求内容过大 | 上传文件或请求体超过接口限制。 |
| 414 | 请求地址过长 | 请求 URL 超过服务端可处理长度,建议减少查询参数或改用 POST。 |
| 415 | 请求内容类型不支持 | 上传或请求体的内容类型不符合接口要求。 |
| 422 | 请求语义错误 | 请求格式正确,但参数取值、语义或业务约束无法处理。 |
| 429 | 请求频率受限 | 默认按来源 IP 限速,单 IP 最多 5 QPS,可满足常规业务调用。超出限制时接口会返回 429 请求频率受限;已购买接口订单可加购 10 QPS 扩展。 |
| 431 | 请求头过大 | 请求头字段过大或过多,建议精简 Header 后重试。 |
| 500 | 服务器内部错误 | 服务端处理异常,请稍后重试。 |
| 502 | 网关或上游错误 | 网关或代理从上游服务收到异常响应。 |
| 503 | 服务暂时不可用 | 服务维护、容量保护或依赖异常导致暂时不可用,请稍后重试。 |
| 504 | 网关超时 | 网关等待上游服务响应超时,可稍后重试或降低请求复杂度。 |

## 接口自定义业务状态码

| 业务状态码 | 业务状态码解释 | 备注 |
| --- | --- | --- |
| 100 | 正常返回 |  |
| 400 | 请求参数无效 |  |
| 401 | APPKEY 无效或未提供 |  |
| 403 | 当前 APPKEY 未开通该产品权益 |  |
| 429 | 超出调用额度 |  |

## cURL 请求示例

```bash
curl --location --request POST 'https://api.gugudata.com/v1/searchVisibilityReports?appkey=APPKEY' \
--header 'Content-Type: application/x-www-form-urlencoded' \
--data-urlencode 'brand=' \
--data-urlencode 'domain=' \
--data-urlencode 'queries=' \
--data-urlencode 'sources=' \
--data-urlencode 'displayName=' \
--data-urlencode 'aliases=' \
--data-urlencode 'competitors=' \
--data-urlencode 'locale=' \
--data-urlencode 'region=' \
--data-urlencode 'maxRank=20' \
--data-urlencode 'includeRawResponse=false'
```

## 常见问题 Q&A

### Q: 数据请求有缓存吗?
A: 接口默认以实时响应为目标。对于日更、月更等具备明确更新周期的数据,会在数据周期内采用缓存与预热策略,以提升响应速度和稳定性;实时查询类接口则以接口说明中的更新频率为准。建议业务侧结合数据时效要求设置本地缓存与重试策略,避免高频重复请求。

### Q: 如何保证请求时 AppKey 的安全性?
A: 用户可以登录咕咕数据开发者中心,在 `APP KEY 管理` 页面复制对应产品的 AppKey;未开通接口时先进入当前接口的购买开通页,已开通或到期续费时进入开发者中心或订单与续费页。建议将 AppKey 保存在服务端环境中,由后端统一调用 API,再向前端或业务系统返回必要结果。不要把 AppKey 写入网页、App 客户端或公开仓库;生产环境建议按系统或业务线拆分 AppKey,并保留调用日志,便于权限控制、审计与问题排查。

### Q: 接口可以用于哪些开发语言?
A: 只要支持 HTTPS 请求的语言和框架均可接入,包括 Java、Python、Node.js、PHP、Go、C#、Swift、Kotlin 等。推荐由后端统一封装调用逻辑,集中处理鉴权、缓存、限流、重试和错误码映射,让 Web、App、AI Agent、内部系统和自动化任务复用同一套数据能力。

### Q: 接口性能可以保证吗?
A: GuGuData API 按生产环境标准部署,持续关注接口稳定性、响应速度与可用性。实际响应时间会受接口类型、请求参数、数据源更新和网络环境影响;建议生产接入前进行联调与压测,并设置合理的超时、重试、降级和告警策略。批量处理或高并发场景可提前评估 QPS、白名单和专属容量方案。

## 服务协议以及服务免责声明

- [服务协议](https://www.gugudata.com/license)
- [服务免责声明](https://www.gugudata.com/disclaimer)

## 技术支持

- 技术支持邮箱: support@gugudata.com
- 微信客服: https://work.weixin.qq.com/kfid/kfcf9a60a6afe3337b7