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

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。

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

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

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

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 (GoogleServiceException $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可能会更新,旧的字段可能被废弃,新的字段可能被添加。错误处理:在实际应用中,务必实现健壮的错误处理机制,捕获GoogleServiceException。通过检查错误码和错误详情,可以更精确地诊断和解决问题。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获取所需的商家位置数据。

以上就是PHP集成Google My Business Business Information API:readMask参数详解与实践的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1261977.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月10日 07:09:04
下一篇 2025年12月10日 07:09:13

相关推荐

  • 如何用PHP写自动化数据报表 PHP数据统计与图表展示

    数据源接入:用pdo处理数据库,guzzle/curl调用api,fgetcsv读取csv文件;2. 数据处理:优先用sql聚合,php做清洗和二次计算;3. 可视化:php输出json,前端用chart.js或echarts渲染图表,实现高效交互式报表。 用PHP来构建自动化数据报表系统,核心在于…

    2025年12月10日 好文分享
    000
  • PHP实现文章自动采集变现 PHP爬虫与内容更新机制

    php实现文章自动采集变现的核心在于爬虫编写、内容清洗与优化、以及变现方式。1. 首先选择合适的爬虫工具,如guzzle、simple html dom parser等,用于高效抓取网页内容。2. 抓取后需解析html,提取标题与正文,并清理广告、无关标签等无用信息。3. 为避免重复内容,需进行伪原…

    2025年12月10日 好文分享
    000
  • PHP调用AI智能创作工具 PHP创意内容辅助生成

    php集成ai内容生成api的关键步骤有:1.选择合适的ai服务提供商并获取api密钥;2.使用guzzle等http客户端库发送带认证信息的post请求;3.构造包含prompt、模型参数等的json请求体;4.解析返回的json数据提取生成内容;5.实现完善的错误处理机制。此外,为提升效率,可采…

    2025年12月10日 好文分享
    000
  • CodeIgniter集成Google登录500错误排查与修复指南

    本文旨在解决CodeIgniter项目中集成Google登录时遇到的500服务器内部错误,该错误通常发生在尝试通过fetchAccessTokenWithAuthCode方法获取Google访问令牌时。核心问题源于底层Guzzle HTTP客户端库中一个变量的类型不匹配,导致count()函数调用异…

    2025年12月10日
    000
  • PHP中数组对象按指定属性合并与数值求和的实现指南

    本文详细介绍了在PHP中如何处理包含重复对象的数组,并根据特定属性(如用户ID)进行合并,同时对另一个属性(如积分)进行累加求和。通过实例代码,展示了使用json_decode、array_reduce和array_sum等函数实现数据分组、聚合的步骤,旨在帮助开发者高效地整理和分析结构化数据。 在…

    2025年12月10日
    000
  • 解决 jQuery Ajax POST 请求错误处理失效问题

    本文旨在解决在使用 jQuery Ajax POST 请求与 PHP 后端交互时,错误处理机制(error block)失效的问题。通过分析常见原因,并结合实际代码示例,提供有效的解决方案,确保在数据库连接失败、SQL 错误等情况下,前端能够正确捕获并处理异常,从而提升用户体验和应用程序的健壮性。 …

    2025年12月10日
    000
  • PHP调用AI图像识别服务 PHP安防监控智能分析

    php调用ai图像识别服务实现安防监控智能分析,关键步骤包括:1.选择合适的服务提供商,如阿里云、腾讯云等,考虑识别精度、稳定性、价格及api易用性;2.注册账号并获取api密钥(appid、appkey)用于身份验证;3.图像预处理,使用gd库或imagick压缩、格式转换、裁剪图像,降低文件大小…

    2025年12月10日 好文分享
    000
  • 解决Arduino通过PHP脚本向数据库发送数据时遇到的问题

    本文旨在帮助解决Arduino通过PHP脚本向数据库传输数据时,PHP接收到的变量值始终为”0″的问题。通过分析Arduino代码中的HTTP请求构建方式,提供正确的代码示例,确保数据能够正确地从Arduino发送到PHP脚本,并最终存储到数据库中。 在将Arduino传感器…

    2025年12月10日
    000
  • 如何用PHP结合AI实现情感分析 PHP文本情感分类技术应用

    php实现情感分析的核心在于调用外部ai服务或本地模型,而非直接执行机器学习计算。1. php通过http请求调用如google、amazon、azure等ai服务api进行情感分析;2. 使用guzzle等http客户端发送json请求并处理返回结果;3. 对隐私或成本敏感场景,可本地部署pyth…

    2025年12月10日 好文分享
    000
  • Arduino 数据传输至数据库:PHP 脚本集成指南

    本文旨在解决 Arduino 通过 PHP 脚本向数据库传输数据时遇到的常见问题。核心内容包括:修正 Arduino 端 HTTP 请求的构建方式,确保数据正确传递至 PHP 脚本;并提供一份简明的 PHP 脚本示例,用于接收并处理 Arduino 发送的数据,最终将其写入数据库。通过本教程,开发者…

    2025年12月10日
    000
  • 如何用PHP结合AI实现智能语音交互 PHP智能家居控制方案

    php在智能语音交互中不直接进行ai运算,而是作为核心协调者,串联语音处理、自然语言理解和设备控制。1. php接收前端传递的语音转文本结果;2. 将文本发送至自然语言理解(nlu)服务提取意图与实体;3. 根据解析结果执行设备映射、指令生成与状态管理;4. 通过api或消息协议将指令下发至智能设备…

    2025年12月10日 好文分享
    000
  • 如何同步PHP本地与生产环境配置 PHP环境一致化管理方法

    环境不一致导致php开发效率低下和部署风险增加,核心解决方法是“代码化”和“容器化”。1. 推荐使用docker容器化技术,通过dockerfile和docker-compose文件精确控制php版本、扩展、配置及web服务器,确保各环境一致;2. 对不适合容器化的项目,可用vagrant结合ans…

    2025年12月10日 好文分享
    000
  • PHP调用AI图像识别接口 PHP智能图片分析变现方案

    php完全能够调用ai图像识别接口,其核心在于将识别结果转化为实际价值。具体步骤包括:1.获取api凭证;2.准备base64编码的图片数据;3.构建json格式请求体;4.发送http post请求;5.解析返回的json响应并处理异常。服务商选择需考虑识别精度、价格模型、文档质量、数据合规性及服…

    2025年12月10日 好文分享
    000
  • 如何正确处理 jQuery Ajax POST 请求中的错误

    本文旨在解决 jQuery Ajax POST 请求中 error 回调函数无法被触发的问题。通过修改 PHP 后端代码,使其在发生错误时返回相应的错误信息,并在 Ajax 的 success 回调函数中判断返回的数据,从而实现对错误的正确处理。 关键在于 PHP 端需要显式地返回错误信息,客户端才…

    2025年12月10日
    000
  • 捕获 Ajax POST 请求错误

    本文旨在解决在使用 jQuery 和 PHP 进行数据库操作时,Ajax POST 请求的错误捕获问题。当数据库服务器离线或 SQL 语句执行出错时,如何确保 Ajax 请求的 error 回调函数能够被正确触发?本文将提供一种有效的解决方案,通过修改 PHP 脚本,将错误信息传递到 success…

    2025年12月10日
    000
  • 如何用PHP写内容分发平台 PHP内容管理与发布流程

    要设计一个高效的php内容管理系统数据库结构,首先需要创建文章存储表,包含标题、正文、作者、发布日期和分类字段。其次,添加标签功能,通过独立的标签表和关联表实现多对多关系。最后,实现用户权限管理,通过用户表和角色表定义不同角色及其权限。为提升系统性能和安全性,可采用缓存技术、cdn加速、数据库优化、…

    2025年12月10日 好文分享
    000
  • 如何用Wamp搭建PHP开发环境 WampServer安装PHP流程介绍

    wampserver安装#%#$#%@%@%$#%$#%#%#$%@_e1bfd762321e409c++ee4ac0b6e841963c的流程包括下载、安装、配置和测试。首先访问官网下载对应系统的版本;其次安装时选择语言、接受协议、指定安装目录并选择所需组件如最新apache、mysql和php版…

    2025年12月10日 好文分享
    000
  • 解决PhpStorm中使用Git钩子与Docker容器交互时数据库连接问题

    正如摘要所述,本文将指导你如何修改Git钩子脚本,使其在Docker容器内部执行数据库相关的命令,从而解决在PhpStorm中使用Git钩子时,由于本地环境与Docker容器环境不一致导致的数据库连接问题。 在使用PhpStorm进行PHP项目开发,并结合Docker容器和Git钩子时,经常会遇到一…

    2025年12月10日
    000
  • 如何在MacOS配置PHP支持MySQL Mac系统PHP连接数据库设置方法

    要让php在macos上连接mysql,核心是安装mysql扩展并配置连接信息。1.使用homebrew安装或更新php和mysql,确保php版本较新且路径正确;2.编辑php.ini文件,启用mysqli和pdo_mysql扩展;3.配置mysql服务开机自启并启动;4.重启web服务器使配置生…

    2025年12月10日 好文分享
    000
  • 使用 PHP 加载 IP 范围列表进行访问控制

    本文介绍了如何使用 PHP 从文本文件或 URL 加载 IP 范围列表,并利用这些 IP 范围对用户访问进行控制。通过 file_get_contents 函数读取 IP 列表,并使用 in_array 函数检查用户 IP 是否在允许的 IP 列表中,从而实现简单的 IP 访问控制。本文提供了详细的…

    2025年12月10日
    000

发表回复

登录后才能评论
关注微信