0

0

如何在 WooCommerce 结账页向用户发送定制化邮件通知

聖光之護

聖光之護

发布时间:2026-02-12 17:05:57

|

829人浏览过

|

来源于php中文网

原创

如何在 WooCommerce 结账页向用户发送定制化邮件通知

本文详解如何在用户访问 woocommerce 结账页面且购物车非空时,精准、单次触发个性化邮件通知,并规避常见误用钩子导致的重复发送问题。

在 WooCommerce 开发中,为提升转化率或增强用户引导,常需在用户进入结账流程时发送即时提醒邮件(如“您的订单即将完成!”)。但若错误选用钩子(如 woocommerce_after_shop_loop_item),不仅无法命中结账页,还可能因页面多次渲染或 AJAX 请求导致邮件重复发送——这正是原始代码的核心缺陷。

✅ 正确钩子:woocommerce_before_checkout_form

该钩子仅在 WooCommerce 结账表单渲染前执行一次,且严格限定于 /checkout/ 页面上下文,是实现「结账页单次触发」的理想入口。同时,必须前置校验 WC()->cart 实例是否存在,避免在非 WooCommerce 环境(如后台或自定义页面)中引发 PHP 错误。

以下是经过生产环境验证的完整实现:

Knowt
Knowt

Knowt是一款AI驱动的在线学习工具

下载
function send_checkout_entry_notification() {
    // 仅对已登录用户生效
    if ( ! is_user_logged_in() ) {
        return;
    }

    // 安全检查:确保 WooCommerce 购物车对象可用
    if ( ! WC()->cart instanceof WC_Cart ) {
        return;
    }

    // 仅当购物车非空时继续
    if ( WC()->cart->is_empty() ) {
        return;
    }

    $current_user = wp_get_current_user();
    $email = $current_user->user_email;
    $name  = $current_user->user_firstname;

    // 防御性检查:邮箱与姓名不能为空
    if ( empty( $email ) || empty( $name ) ) {
        return;
    }

    // 构建邮件内容(使用 WordPress 国际化函数,便于多语言支持)
    $subject = sprintf( __( 'Hello %s, your purchase is almost ready!', 'your-textdomain' ), esc_html( $name ) );
    $body    = sprintf(
        __( 'Hi %s,<br><br>Your cart contains %d item(s). Proceed to checkout to complete your order!', 'your-textdomain' ),
        esc_html( $name ),
        WC()->cart->get_cart_contents_count()
    );

    $headers = array( 'Content-Type: text/html; charset=UTF-8' );

    // 发送邮件(注意:wp_mail 是异步的,无需额外处理)
    wp_mail( $email, $subject, $body, $headers );
}
add_action( 'woocommerce_before_checkout_form', 'send_checkout_entry_notification' );

? 进阶建议:复用 WooCommerce 邮件模板样式

若希望通知邮件与 WooCommerce 默认邮件(如订单确认)保持视觉一致(含品牌头图、CSS 样式、响应式布局),推荐使用 WooCommerce 内置邮件系统:

// 替换上述 wp_mail() 调用部分如下:
if ( ! empty( $email ) && ! empty( $name ) ) {
    $mailer = WC()->mailer();

    $to      = $email;
    $subject = __( 'Your Checkout Is Ready', 'your-textdomain' );
    $message = $mailer->wrap_message(
        sprintf( __( 'Hello %s', 'your-textdomain' ), esc_html( $name ) ),
        sprintf(
            __( 'You have %d item(s) in your cart. <a href="%s">Go to checkout now</a>!', 'your-textdomain' ),
            WC()->cart->get_cart_contents_count(),
            wc_get_checkout_url()
        )
    );

    $mailer->send( $to, $subject, $message );
}
⚠️ 重要注意事项 勿在循环或 AJAX 回调中直接调用:woocommerce_before_checkout_form 已天然保证单次执行,无需额外加锁或 session 标记; 避免敏感信息泄露:示例中使用 esc_html() 对用户输入进行转义,防止 XSS; 测试务必启用日志:可临时添加 error_log( 'Checkout notification sent to ' . $email ); 辅助调试; 生产环境建议加入频率限制:例如通过 update_user_meta() 记录最近发送时间,防止用户刷新页面反复触发。

通过以上方案,您将获得一个稳定、安全、可维护的结账页邮件通知机制,既符合 WooCommerce 最佳实践,又为后续扩展(如集成 Mailchimp 或添加动态商品摘要)预留清晰接口。

相关标签:

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
ajax教程
ajax教程

php中文网为大家带来ajax教程合集,Ajax是一种用于创建快速动态网页的技术。通过在后台与服务器进行少量数据交换,Ajax可以使网页实现异步更新。这意味着可以在不重新加载整个网页的情况下,对网页的某部分进行更新。php中文网还为大家带来ajax的相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

163

2023.06.14

ajax中文乱码解决方法
ajax中文乱码解决方法

ajax中文乱码解决方法有设置请求头部的字符编码、在服务器端设置响应头部的字符编码和使用encodeURIComponent对中文进行编码。本专题为大家提供ajax中文乱码相关的文章、下载、课程内容,供大家免费下载体验。

164

2023.08.31

ajax传递中文乱码怎么办
ajax传递中文乱码怎么办

ajax传递中文乱码的解决办法:1、设置统一的编码方式;2、服务器端编码;3、客户端解码;4、设置HTTP响应头;5、使用JSON格式。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

119

2023.11.15

ajax网站有哪些
ajax网站有哪些

使用ajax的网站有谷歌、维基百科、脸书、纽约时报、亚马逊、stackoverflow、twitter、hacker news、shopify和basecamp等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

243

2024.09.24

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

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

325

2023.10.17

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

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

771

2023.10.18

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

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

96

2025.08.19

硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

1393

2023.10.19

c语言 数据类型
c语言 数据类型

本专题整合了c语言数据类型相关内容,阅读专题下面的文章了解更多详细内容。

1

2026.02.12

热门下载

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

精品课程

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

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