当前位置:首页 > 文章列表 > 文章 > php教程 > WooCommerce自动取消失败订单技巧

WooCommerce自动取消失败订单技巧

2025-07-18 23:39:21 0浏览 收藏

在IT行业这个发展更新速度很快的行业,只有不停止的学习,才不会被行业所淘汰。如果你是文章学习者,那么本文《WooCommerce 自动取消失败订单方法》就很适合你!本篇内容主要包括##content_title##,希望对大家的知识积累有所帮助,助力实战开发!

自动取消 WooCommerce 中支付失败的订单

本文旨在解决 WooCommerce 订单在支付失败后,无法自动更改为“已取消”状态的问题。通过修改现有的 mu-plugin 代码,利用 woocommerce_cancel_unpaid_orders 钩子,实现订单状态的自动更新,从而提高商店管理的效率。

在 WooCommerce 商店运营中,经常会遇到客户下单后未能成功支付的情况。为了简化订单管理流程,需要将这些支付失败的订单自动变更为“已取消”状态。以下提供一种解决方案,通过自定义插件,实现 WooCommerce 中支付失败订单的自动取消功能。

解决方案:使用 woocommerce_cancel_unpaid_orders 钩子

原代码尝试使用 woocommerce_cancel_unpaid_submitted 钩子,但该钩子不存在。正确的钩子应该是 woocommerce_cancel_unpaid_orders。这个钩子专门用于处理未支付订单的取消操作。

下面是修改后的 mu-plugin 代码:

<?php
/**
 * Plugin Name: Auto Cancel Failed Orders
 * Description: Automatically cancels WooCommerce orders with "Failed" status after a specified delay.
 * Version: 1.0
 */

add_action( 'woocommerce_cancel_unpaid_orders', 'cancel_failed_orders' );

function cancel_failed_orders() {
    $days_delay = 1; // 设置延迟天数
    $one_day    = 24 * 60 * 60;
    $today      = strtotime( date('Y-m-d') );

    $args = array(
        'limit'        => -1,
        'status'       => 'failed', // 注意这里使用 'failed' 而不是 'wc-failed'
        'date_created' => '<' . ( $today - ($days_delay * $one_day) ),
    );

    $failed_orders = wc_get_orders( $args );

    if ( !empty( $failed_orders ) ) {
        $cancelled_text = __("No successful payment", "woocommerce");

        foreach ( $failed_orders as $order ) {
            $order->update_status( 'cancelled', $cancelled_text ); // 注意这里使用 'cancelled' 而不是 'wc-cancelled'
        }
    }
}

代码解释:

  1. add_action( 'woocommerce_cancel_unpaid_orders', 'cancel_failed_orders' );: 将 cancel_failed_orders 函数挂载到 woocommerce_cancel_unpaid_orders 钩子上。这意味着 WooCommerce 会定期(默认情况下是每小时)触发该钩子,执行 cancel_failed_orders 函数。
  2. $days_delay = 1;: 设置订单在支付失败后多少天自动取消。这里设置为 1 天。
  3. $one_day = 24 * 60 * 60;: 计算一天有多少秒。
  4. $today = strtotime( date('Y-m-d') );: 获取今天的 UNIX 时间戳。
  5. $args 数组: 定义了查询订单的参数。
    • 'limit' => -1:获取所有符合条件的订单。
    • 'status' => 'failed':指定订单状态为 "failed"。注意:这里使用 'failed' 而不是 'wc-failed'。
    • 'date_created' => '<' . ( $today - ($days_delay * $one_day) ):筛选出创建日期早于 $days_delay 天前的订单。
  6. $failed_orders = wc_get_orders( $args );: 使用 wc_get_orders() 函数获取符合条件的订单对象。
  7. if ( !empty( $failed_orders ) ): 检查是否找到符合条件的订单。
  8. $cancelled_text = __("No successful payment", "woocommerce");: 定义取消订单时添加的注释文本。
  9. foreach ( $failed_orders as $order ): 循环遍历所有符合条件的订单。
  10. $order->update_status( 'cancelled', $cancelled_text );: 将订单状态更新为 "cancelled",并添加注释。注意:这里使用 'cancelled' 而不是 'wc-cancelled'。

使用方法:

  1. 将上述代码保存为一个 PHP 文件,例如 auto-cancel-failed-orders.php。
  2. 将该文件上传到你的 WordPress 站点的 wp-content/mu-plugins/ 目录中。 如果 mu-plugins 目录不存在,则需要创建它。
  3. 无需激活插件,mu-plugins 目录下的 PHP 文件会自动加载。

注意事项:

  • 状态值: 务必使用正确的状态值,'failed' 和 'cancelled',而不是 'wc-failed' 和 'wc-cancelled'。 WooCommerce 状态值不应包含 wc- 前缀。
  • 延迟时间: 根据实际需求调整 $days_delay 的值。
  • 测试: 在生产环境中使用之前,请务必在测试环境中进行充分测试。
  • 计划任务: woocommerce_cancel_unpaid_orders 钩子依赖于 WooCommerce 的计划任务系统。 确保你的 WordPress 站点正确配置了 WP-Cron,或者使用服务器端的 Cron 作业来触发 WordPress 的计划任务。

总结:

通过使用 woocommerce_cancel_unpaid_orders 钩子,可以有效地自动取消 WooCommerce 中支付失败的订单,从而简化订单管理流程,提高工作效率。 请确保正确配置代码,并在生产环境中使用前进行充分测试。

文中关于的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《WooCommerce自动取消失败订单技巧》文章吧,也可关注golang学习网公众号了解相关技术文章。

Linux权限与ACL管理技巧Linux权限与ACL管理技巧
上一篇
Linux权限与ACL管理技巧
CSS直接子元素选择器详解
下一篇
CSS直接子元素选择器详解
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    542次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    511次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    498次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    484次学习
查看更多
AI推荐
  • AI代码助手:Amazon CodeWhisperer,高效安全的代码生成工具
    CodeWhisperer
    Amazon CodeWhisperer,一款AI代码生成工具,助您高效编写代码。支持多种语言和IDE,提供智能代码建议、安全扫描,加速开发流程。
    11次使用
  • 畅图AI:AI原生智能图表工具 | 零门槛生成与高效团队协作
    畅图AI
    探索畅图AI:领先的AI原生图表工具,告别绘图门槛。AI智能生成思维导图、流程图等多种图表,支持多模态解析、智能转换与高效团队协作。免费试用,提升效率!
    36次使用
  • TextIn智能文字识别:高效文档处理,助力企业数字化转型
    TextIn智能文字识别平台
    TextIn智能文字识别平台,提供OCR、文档解析及NLP技术,实现文档采集、分类、信息抽取及智能审核全流程自动化。降低90%人工审核成本,提升企业效率。
    44次使用
  • SEO  简篇 AI 排版:3 秒生成精美文章,告别排版烦恼
    简篇AI排版
    SEO 简篇 AI 排版,一款强大的 AI 图文排版工具,3 秒生成专业文章。智能排版、AI 对话优化,支持工作汇报、家校通知等数百场景。会员畅享海量素材、专属客服,多格式导出,一键分享。
    40次使用
  • SEO  小墨鹰 AI 快排:公众号图文排版神器,30 秒搞定精美排版
    小墨鹰AI快排
    SEO 小墨鹰 AI 快排,新媒体运营必备!30 秒自动完成公众号图文排版,更有 AI 写作助手、图片去水印等功能。海量素材模板,一键秒刷,提升运营效率!
    38次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码