0

0

如何安全调用 WooCommerce 订单对象的 get_data() 方法

聖光之護

聖光之護

发布时间:2026-01-25 11:42:02

|

585人浏览过

|

来源于php中文网

原创

如何安全调用 WooCommerce 订单对象的 get_data() 方法

当使用 `wc_get_order()` 获取订单失败时,该函数会返回 `false` 而非订单对象,直接调用 `->get_data()` 将触发“call to a member function on boolean”致命错误。本文详解原因、修复方案及最佳实践。

在 WooCommerce 开发中,wc_get_order( $order_id ) 是获取订单实例的标准方式。但它并非总是返回 WC_Order 对象——当传入的 $order_id 不存在、已被删除、ID 类型错误(如字符串未转整型)、或数据库异常时,该函数将返回布尔值 false。

你遇到的报错:

Fatal error: Uncaught Error: Call to a member function get_data() on boolean

正是源于以下代码未做类型校验:

阿里云AI平台
阿里云AI平台

阿里云AI平台

下载
$order_id = 12;
$order = wc_get_order( $order_id );
$order_data = $order->get_data(); // ❌ $order 可能为 false!

✅ 正确做法:始终检查订单对象有效性

推荐使用严格比较 !== false(而非 !$order,避免误判 ID 为 0 的订单):

$order_id = 12;
$order = wc_get_order( $order_id );

if ( $order !== false && $order instanceof WC_Order ) {
    $order_data = $order->get_data(); // ✅ 安全调用

    $order_id        = $order_data['id'];
    $order_parent_id = $order_data['parent_id'];
    $order_status    = $order_data['status'];

    // 后续逻辑(如输出、日志、状态判断等)
    error_log( "Order #{$order_id} status: {$order_status}" );
} else {
    error_log( "⚠️ Failed to load order with ID: {$order_id}" );
    // 可选:抛出异常、返回默认值、重定向或显示用户友好提示
}

? 补充排查建议

  • 确认订单真实存在:登录 WordPress 后台 → WooCommerce → 订单,核实 ID 12 是否存在且未被彻底删除(回收站中的订单仍可获取)。
  • 检查 ID 类型:确保 $order_id 是整数。若来自 URL 参数(如 ?order=12),请强制转换:
    $order_id = absint( $_GET['order'] ?? 0 );
  • 避免硬编码 ID:生产环境应动态获取订单 ID(如通过 $woocommerce-youjiankuohaophpcnsession->get('order_awaiting_payment') 或钩子上下文)。
  • 启用调试:在 wp-config.php 中开启 WP_DEBUG_LOG,便于捕获底层错误。

? 总结

WooCommerce 的 wc_get_order() 是一个“防御性”函数——它优先保障健壮性,而非抛出异常。开发者有责任在调用其返回值的方法前,显式验证对象有效性。加上 !== false && instanceof WC_Order 双重检查,即可彻底规避此类致命错误,并提升代码的稳定性与可维护性。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

WorkBuddy
WorkBuddy

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
java中boolean的用法
java中boolean的用法

在Java中,boolean是一种基本数据类型,它只有两个可能的值:true和false。boolean类型经常用于条件测试,比如进行比较或者检查某个条件是否满足。想了解更多java中boolean的相关内容,可以阅读本专题下面的文章。

367

2023.11.13

java boolean类型
java boolean类型

本专题整合了java中boolean类型相关教程,阅读专题下面的文章了解更多详细内容。

42

2025.11.30

session失效的原因
session失效的原因

session失效的原因有会话超时、会话数量限制、会话完整性检查、服务器重启、浏览器或设备问题等等。详细介绍:1、会话超时:服务器为Session设置了一个默认的超时时间,当用户在一段时间内没有与服务器交互时,Session将自动失效;2、会话数量限制:服务器为每个用户的Session数量设置了一个限制,当用户创建的Session数量超过这个限制时,最新的会覆盖最早的等等。

336

2023.10.17

session失效解决方法
session失效解决方法

session失效通常是由于 session 的生存时间过期或者服务器关闭导致的。其解决办法:1、延长session的生存时间;2、使用持久化存储;3、使用cookie;4、异步更新session;5、使用会话管理中间件。

776

2023.10.18

cookie与session的区别
cookie与session的区别

本专题整合了cookie与session的区别和使用方法等相关内容,阅读专题下面的文章了解更详细的内容。

97

2025.08.19

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

761

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

221

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1568

2023.10.24

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

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

26

2026.03.13

热门下载

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

精品课程

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

共137课时 | 13.5万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 11.3万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 1.0万人学习

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

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