0

0

Google My Business API v1:解决 readMask 参数 INVALID_ARGUMENT 错误

心靈之曲

心靈之曲

发布时间:2025-07-03 19:32:01

|

755人浏览过

|

来源于php中文网

原创

Google My Business API v1:解决 readMask 参数 INVALID_ARGUMENT 错误

本文旨在解决在使用 Google My Business Business Information API 的 accounts.locations.list 方法时,因 readMask 参数不正确导致 INVALID_ARGUMENT 错误的常见问题。我们将深入分析错误原因,明确指出 readMask 必须指定 Location 资源本身的有效属性,而非其他关联实体字段。通过提供正确的参数使用方法和示例代码,帮助开发者顺利获取所需的商家位置信息,避免不必要的API调用失败。

随着 google my business api 旧版本的逐步弃用,开发者需要迁移到新的 api 服务,例如 google_service_mybusinessbusinessinformation 来管理商家位置信息。在进行位置列表查询时,readmask 参数是一个关键的字段,它允许开发者指定希望在响应中返回的特定字段,从而优化数据传输和处理效率。然而,不正确的 readmask 值常常导致 http 400 invalid_argument 错误。

诊断 readMask 错误:INVALID_ARGUMENT

当您尝试使用 Google_Service_MyBusinessBusinessInformation 服务的 accounts.locations.list 方法,并传入一个无效的 readMask 时,API 会返回一个典型的 Google\Service\Exception #400 错误,其详细信息如下:

{
  "error": {
    "code": 400,
    "message": "Request contains an invalid argument.",
    "status": "INVALID_ARGUMENT",
    "details": [
      {
        "@type": "type.googleapis.com/google.rpc.BadRequest",
        "fieldViolations": [
          {
            "field": "read_mask",
            "description": "Invalid field mask provided"
          }
        ]
      }
    ]
  }
}

这个错误明确指出 read_mask 字段存在问题,即提供了“无效的字段掩码”。问题通常在于 readMask 中包含了不属于 Location 资源本身的属性,或者属性名称拼写错误。例如,尝试获取 user.display_name 这样的字段,它并非 Location 资源的标准属性。

核心问题:readMask 参数的正确使用

readMask 参数的作用是告诉 API 您需要响应中包含哪些特定的字段。对于 accounts.locations.list 方法,readMask 中的字段必须是 Location 资源(Google_Service_MyBusinessBusinessInformation_Location 对象)的有效属性。这意味着您不能随意指定任何与位置相关的字段,而必须参照 Google My Business Business Information API v1 文档中 Location 资源的定义。

常见的错误是将其他服务或关联实体(如用户账户)的字段混入 Location 的 readMask 中。例如,user.display_name 显然不属于 Location 资源,因此会导致 INVALID_ARGUMENT 错误。即使是 photo 这样的字段,虽然 Location 资源中包含照片信息,但其具体的引用方式也需符合API规范,通常是直接指定 photos 字段以获取照片列表或相关元数据。

有效的 Location 资源属性示例包括:

零沫AI工具导航
零沫AI工具导航

零沫AI工具导航-AI导航新标杆,探索全球实用AI工具

下载
  • name:位置的资源名称。
  • title:商家名称。
  • websiteUri:商家网站的URI。
  • address:商家地址。
  • latlng:经纬度。
  • primaryCategory:主要业务类别。
  • phoneNumbers:电话号码。
  • openInfo:营业状态信息。
  • photos:照片信息(如果需要获取照片详情,可能需要进一步的API调用或特定的字段组合)。
  • metadata:元数据。
  • storeCode:商家自定义的店铺代码。

请务必查阅官方文档: Google My Business Business Information API v1 Location 资源: https://www.php.cn/link/dc8ea2d055557e14585d74fc6c1033b2

解决方案与示例代码

解决 readMask 错误的关键在于确保 readMask 中只包含 Location 资源中定义的有效属性。以下是修正后的 PHP 代码示例,展示了如何正确构造 readMask:

<?php

// 假设 $client 已经是一个经过认证的 Google_Client 实例
// 并且已经包含了 Google My Business API 相关的服务类

// 1. 初始化 My Business Account Management 服务以获取账户信息
$my_business_account = new Google_Service_MyBusinessAccountManagement($client);
$list_accounts_response = $my_business_account->accounts->listAccounts();

// 确保至少有一个账户
if (empty($list_accounts_response)) {
    die("No Google My Business accounts found.");
}

// 获取第一个账户的名称,通常用于后续API调用
$account = $list_accounts_response[0];
$accountName = $account->name; // 例如:accounts/1234567890

// 2. 初始化 My Business Business Information 服务
$mybusinessService = new Google_Service_MyBusinessBusinessInformation($client);
$locationsService = $mybusinessService->accounts_locations;

// 3. 定义正确的 queryParams,特别是 readMask
// readMask 必须包含 Location 资源中定义的有效字段
$queryParams = [
    "pageSize" => 10,
    // 正确的 readMask 示例:只请求 Location 资源中的 'name', 'title' 和 'websiteUri' 字段
    'readMask' => "name,title,websiteUri,address,primaryCategory,phoneNumbers"
    // 如果需要照片信息,通常直接指定 'photos' 字段,但获取详细照片URL可能需要额外的API调用或在photos字段中包含子字段
    // 'readMask' => "name,title,photos" // 示例:请求名称、标题和照片信息
];

try {
    // 4. 调用 listAccountsLocations 方法获取位置列表
    $locationsList = $locationsService->listAccountsLocations($accountName, $queryParams);

    // 遍历并打印获取到的位置信息
    if ($locationsList->getLocations()) {
        echo "Successfully retrieved locations:\n";
        foreach ($locationsList->getLocations() as $location) {
            echo "  Location Name: " . $location->getName() . "\n";
            echo "  Location Title: " . $location->getTitle() . "\n";
            echo "  Website URI: " . $location->getWebsiteUri() . "\n";
            // 访问其他字段,例如地址
            if ($location->getAddress()) {
                echo "  Address: " . $location->getAddress()->getPostalAddress()->getLocality() . ", " . $location->getAddress()->getPostalAddress()->getRegionCode() . "\n";
            }
            echo "---\n";
        }
    } else {
        echo "No locations found for this account.\n";
    }

} catch (Google\Service\Exception $e) {
    // 捕获并处理 API 错误
    echo "An error occurred: " . $e->getMessage() . "\n";
    echo "Error details: " . $e->getErrors()[0]['message'] . "\n";
    if (isset($e->getErrors()[0]['details'][0]['fieldViolations'])) {
        foreach ($e->getErrors()[0]['details'][0]['fieldViolations'] as $violation) {
            echo "  Field Violation: " . $violation['field'] . " - " . $violation['description'] . "\n";
        }
    }
} catch (Exception $e) {
    // 捕获其他通用错误
    echo "An unexpected error occurred: " . $e->getMessage() . "\n";
}

?>

在上述代码中,'readMask' => "name,title,websiteUri,address,primaryCategory,phoneNumbers" 是一个有效的示例。它仅请求 Location 资源中明确定义的字段,从而避免了 INVALID_ARGUMENT 错误。

重要注意事项

  1. 查阅官方文档是关键: 始终以 Google API 的官方文档为准,特别是关于特定资源(如 Location)的字段定义。这是确保 readMask 参数正确性的最可靠方法。
  2. 按需请求字段: 仅在 readMask 中指定您实际需要的字段。这不仅能减少API响应的大小,降低网络延迟,还能提高API调用的效率和性能。请求不必要的字段会浪费资源。
  3. 错误处理: 在您的代码中实现健壮的错误处理机制。捕获 Google\Service\Exception 可以帮助您诊断和处理 API 返回的特定错误,例如 INVALID_ARGUMENT。
  4. API 凭证和权限: 确保您的 Google Cloud 项目已启用 Google My Business API,并且您的服务账户或OAuth 2.0 凭证拥有足够的权限来访问 My Business 账户和位置信息。

总结

readMask 参数在 Google My Business Business Information API 中是一个强大的工具,用于精细控制 API 响应中返回的数据。解决 INVALID_ARGUMENT 错误的关键在于理解 readMask 必须引用目标资源(在本例中是 Location)的有效、直接的属性。通过仔细查阅 API 文档并遵循示例代码中的最佳实践,您可以有效地利用 readMask 来优化您的 API 集成,确保顺利获取所需的商家位置数据。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
location.assign
location.assign

在前端开发中,我们经常需要使用JavaScript来控制页面的跳转和数据的传递。location.assign就是JavaScript中常用的一个跳转方法。通过location.assign,我们可以在当前窗口或者iframe中加载一个新的URL地址,并且可以保存旧页面的历史记录。php中文网为大家带来了location.assign的相关知识、以及相关文章等内容,供大家免费下载使用。

232

2023.06.27

http500解决方法
http500解决方法

http500解决方法有检查服务器日志、检查代码错误、检查服务器配置、检查文件和目录权限、检查资源不足、更新软件版本、重启服务器或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

495

2023.11.09

http请求415错误怎么解决
http请求415错误怎么解决

解决方法:1、检查请求头中的Content-Type;2、检查请求体中的数据格式;3、使用适当的编码格式;4、使用适当的请求方法;5、检查服务器端的支持情况。更多http请求415错误怎么解决的相关内容,可以阅读下面的文章。

450

2023.11.14

HTTP 503错误解决方法
HTTP 503错误解决方法

HTTP 503错误表示服务器暂时无法处理请求。想了解更多http错误代码的相关内容,可以阅读本专题下面的文章。

3579

2024.03.12

http与https有哪些区别
http与https有哪些区别

http与https的区别:1、协议安全性;2、连接方式;3、证书管理;4、连接状态;5、端口号;6、资源消耗;7、兼容性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

2915

2024.08.16

http与https有哪些区别
http与https有哪些区别

http与https的区别:1、协议安全性;2、连接方式;3、证书管理;4、连接状态;5、端口号;6、资源消耗;7、兼容性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

2915

2024.08.16

Python异步编程与Asyncio高并发应用实践
Python异步编程与Asyncio高并发应用实践

本专题围绕 Python 异步编程模型展开,深入讲解 Asyncio 框架的核心原理与应用实践。内容包括事件循环机制、协程任务调度、异步 IO 处理以及并发任务管理策略。通过构建高并发网络请求与异步数据处理案例,帮助开发者掌握 Python 在高并发场景中的高效开发方法,并提升系统资源利用率与整体运行性能。

37

2026.03.12

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

136

2026.03.11

Go高并发任务调度与Goroutine池化实践
Go高并发任务调度与Goroutine池化实践

本专题围绕 Go 语言在高并发任务处理场景中的实践展开,系统讲解 Goroutine 调度模型、Channel 通信机制以及并发控制策略。内容包括任务队列设计、Goroutine 池化管理、资源限制控制以及并发任务的性能优化方法。通过实际案例演示,帮助开发者构建稳定高效的 Go 并发任务处理系统,提高系统在高负载环境下的处理能力与稳定性。

47

2026.03.10

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 6万人学习

ASP 教程
ASP 教程

共34课时 | 5.9万人学习

Vue3.x 工具篇--十天技能课堂
Vue3.x 工具篇--十天技能课堂

共26课时 | 1.6万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号