0

0

PHP集成Google My Business Business Information API:readMask参数详解与实践

聖光之護

聖光之護

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

|

677人浏览过

|

来源于php中文网

原创

PHP集成Google My Business Business Information API:readMask参数详解与实践

本文旨在解决在使用PHP客户端库调用Google My Business Business Information API获取商家位置列表时,因readMask参数配置不当导致的400错误。核心问题在于readMask必须指定Location资源中有效的字段,而非其他不相关的属性。文章将提供正确的readMask用法示例,帮助开发者顺利迁移至新版API并高效获取所需商家数据。

理解Google My Business Business Information API (v1) 与 readMask

随着google my business api从v4版本迁移至最新的business information api (v1),开发者在获取商家位置信息时可能会遇到新的挑战。其中一个常见问题是关于readmask参数的正确使用。readmask是一个关键字段,它允许api调用者指定只返回资源中需要的部分字段,从而优化数据传输效率和减少不必要的数据量。

INVALID_ARGUMENT 错误及其根源

在使用Google_Service_MyBusinessBusinessInformation服务获取商家位置列表时,如果readMask参数被错误地设置为user.display_name或photo等不属于Location资源本身的字段,API会返回HTTP 400 Bad Request错误,并附带INVALID_ARGUMENT和Invalid field mask provided的详细信息。

{
  "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"
          }
        ]
      }
    ]
  }
}

核心原因在于,readMask参数是针对API返回的Location资源对象的属性进行过滤的。它不能用于请求与Location资源本身不直接关联的其他实体(如用户或图片,除非图片是Location资源的一个直接属性,且通过特定字段名访问)。例如,user.display_name可能是与某个用户账户关联的属性,而photo可能指的是独立的照片资源,它们都不是Location资源顶层直接可用的字段。

Location资源 readMask 的正确用法

要正确使用readMask,必须确保其中包含的字段名是Location资源中定义的有效属性。这些属性包括但不限于:

  • name:资源的完整名称(例如 accounts/ACCOUNT_ID/locations/LOCATION_ID)。
  • title:商家名称。
  • storeCode:商家代码。
  • websiteUri:网站URL。
  • address:商家地址信息。
  • latlng:经纬度坐标。
  • phoneNumbers:电话号码信息。
  • regularHours:常规营业时间。
  • openInfo:营业状态信息。
  • categories:商家类别。
  • serviceArea:服务区域。

开发者应查阅Google My Business Business Information API的官方文档中关于Location资源字段的详细说明,以获取完整的有效字段列表:https://www.php.cn/link/dc8ea2d055557e14585d74fc6c1033b2

AITDK
AITDK

免费AI SEO工具,SEO的AI生成器

下载

立即学习PHP免费学习笔记(深入)”;

PHP 代码示例:正确获取商家位置列表

以下是一个修正后的PHP代码示例,演示了如何正确配置readMask参数以获取商家位置列表:

<?php

require_once 'vendor/autoload.php'; // 确保你的Composer autoload文件已加载

// 假设 $client 已经是一个经过认证的 Google_Client 实例
// 并且已经设置了正确的Scopes,例如 Google_Service_MyBusinessBusinessInformation::MYBUSINESS_BUSINESSINFORMATION
// 示例:
// $client = new Google_Client();
// $client->setAuthConfig('path/to/your/credentials.json');
// $client->setScopes([Google_Service_MyBusinessBusinessInformation::MYBUSINESS_BUSINESSINFORMATION, Google_Service_MyBusinessAccountManagement::MYBUSINESS_ACCOUNTMANAGEMENT]);
// $client->setAccessType('offline'); // 如果需要刷新令牌

try {
    // 1. 获取账户信息
    $my_business_account = new Google_Service_MyBusinessAccountManagement($client);
    $list_accounts_response = $my_business_account->accounts->listAccounts();

    if (empty($list_accounts_response->getAccounts())) {
        echo "未找到任何Google My Business账户。\n";
        exit;
    }

    // 通常选择第一个账户,或者根据业务逻辑选择特定账户
    $account = $list_accounts_response->getAccounts()[0];
    echo "正在处理账户: " . $account->getName() . "\n";

    // 2. 初始化 MyBusinessBusinessInformation 服务
    $mybusinessService = new Google_Service_MyBusinessBusinessInformation($client);
    $locations_service = $mybusinessService->accounts_locations;

    // 3. 定义查询参数,重点是正确的 readMask
    $queryParams = [
        "pageSize" => 10,
        // 修正:readMask 必须指定 Location 资源本身的有效字段
        // 这里请求了名称、标题、商家代码、网站URI、地址和电话号码
        'readMask' => "name,title,storeCode,websiteUri,address,phoneNumbers"
    ];

    // 4. 调用 API 获取位置列表
    $locationsListResponse = $locations_service->listAccountsLocations($account->name, $queryParams);

    if (empty($locationsListResponse->getLocations())) {
        echo "该账户下未找到任何商家位置。\n";
        exit;
    }

    echo "成功获取商家位置列表:\n";
    foreach ($locationsListResponse->getLocations() as $location) {
        echo "  - 位置名称 (Resource Name): " . $location->getName() . "\n";
        echo "  - 商家标题 (Title): " . $location->getTitle() . "\n";
        if ($location->getStoreCode()) {
            echo "  - 商家代码 (Store Code): " . $location->getStoreCode() . "\n";
        }
        if ($location->getWebsiteUri()) {
            echo "  - 网站 (Website): " . $location->getWebsiteUri() . "\n";
        }
        // 地址字段是一个复杂对象,需要进一步解析
        if ($location->getAddress()) {
            $postalAddress = $location->getAddress()->getPostalAddress();
            if ($postalAddress) {
                echo "  - 地址 (Address): " . implode(", ", $postalAddress->getAddressLines()) . ", " . $postalAddress->getLocality() . "\n";
            }
        }
        // 电话号码字段也是一个复杂对象
        if ($location->getPhoneNumbers() && $location->getPhoneNumbers()->getPrimaryPhone()) {
            echo "  - 主要电话 (Primary Phone): " . $location->getPhoneNumbers()->getPrimaryPhone() . "\n";
        }
        echo "---\n";
    }

    // 处理分页,如果有更多结果
    $nextPageToken = $locationsListResponse->getNextPageToken();
    if ($nextPageToken) {
        echo "还有更多结果,可以通过 nextPageToken 继续获取。\n";
        // 示例:获取下一页
        // $queryParams['pageToken'] = $nextPageToken;
        // $nextLocationsListResponse = $locations_service->listAccountsLocations($account->name, $queryParams);
    }

} catch (Google\Service\Exception $e) {
    echo "API 调用出错: " . $e->getMessage() . "\n";
    echo "错误详情: " . (isset($e->getErrors()[0]['message']) ? $e->getErrors()[0]['message'] : '未知错误') . "\n";
    // 更多错误处理,例如根据错误码进行不同处理
} catch (Exception $e) {
    echo "发生未知错误: " . $e->getMessage() . "\n";
}

?>

注意事项

  • 字段准确性:始终参考Google My Business Business Information API的官方Location资源文档,以获取最新和最准确的有效readMask字段列表。API可能会更新,旧的字段可能被废弃,新的字段可能被添加。
  • 错误处理:在实际应用中,务必实现健壮的错误处理机制,捕获Google\Service\Exception。通过检查错误码和错误详情,可以更精确地诊断和解决问题。
  • API权限与范围:确保你的Google Cloud项目已启用Google My Business Business Information API,并且OAuth 2.0客户端凭据具有访问所需资源的正确权限(Scope),例如https://www.googleapis.com/auth/mybusiness.businessinformation和https://www.googleapis.com/auth/mybusiness.accountmanagement。
  • 分页处理:listAccountsLocations方法支持分页。当结果数量超过pageSize时,API会返回nextPageToken。开发者需要循环调用API,并在后续请求中带上pageToken参数以获取所有数据。
  • 性能优化:readMask的目的是只请求你真正需要的数据。避免请求不必要的字段可以减少API响应大小,从而提高应用程序的性能和响应速度。

总结

通过本文,我们详细探讨了Google My Business Business Information API中readMask参数的正确使用方法。核心要点是:readMask中的字段必须是目标资源(本例中为Location)的有效属性。遵循这一原则,并结合官方文档进行字段验证,将有效避免INVALID_ARGUMENT错误,确保开发者能够顺利、高效地从Google My Business获取所需的商家位置数据。

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

496

2023.11.09

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

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

451

2023.11.14

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

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

3584

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

PHP 高并发与性能优化
PHP 高并发与性能优化

本专题聚焦 PHP 在高并发场景下的性能优化与系统调优,内容涵盖 Nginx 与 PHP-FPM 优化、Opcode 缓存、Redis/Memcached 应用、异步任务队列、数据库优化、代码性能分析与瓶颈排查。通过实战案例(如高并发接口优化、缓存系统设计、秒杀活动实现),帮助学习者掌握 构建高性能PHP后端系统的核心能力。

114

2025.10.16

PHP 数据库操作与性能优化
PHP 数据库操作与性能优化

本专题聚焦于PHP在数据库开发中的核心应用,详细讲解PDO与MySQLi的使用方法、预处理语句、事务控制与安全防注入策略。同时深入分析SQL查询优化、索引设计、慢查询排查等性能提升手段。通过实战案例帮助开发者构建高效、安全、可扩展的PHP数据库应用系统。

99

2025.11.13

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

26

2026.03.13

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
第二十四期_PHP8编程
第二十四期_PHP8编程

共86课时 | 3.5万人学习

成为PHP架构师-自制PHP框架
成为PHP架构师-自制PHP框架

共28课时 | 2.6万人学习

第二十三期_PHP编程
第二十三期_PHP编程

共93课时 | 7.5万人学习

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

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