0

0

如何在自定义文章类型后台添加安全的邮件发送按钮(基于 AJAX 实现)

花韻仙語

花韻仙語

发布时间:2026-03-08 09:55:10

|

315人浏览过

|

来源于php中文网

原创

如何在自定义文章类型后台添加安全的邮件发送按钮(基于 AJAX 实现)

本文详解如何在 WordPress 自定义文章类型编辑页中,通过 AJAX 安全集成 wp_mail() 发送邮件,避免表单提交导致的页面跳转与 HTML 标签被过滤问题,并提供完整可运行代码与关键注意事项。

本文详解如何在 wordpress 自定义文章类型编辑页中,通过 ajax 安全集成 `wp_mail()` 发送邮件,避免表单提交导致的页面跳转与 html 标签被过滤问题,并提供完整可运行代码与关键注意事项。

在 WordPress 后台为自定义文章类型(如 quote)添加“发送邮件”按钮时,若直接使用传统

提交至 admin-post.php,常会遇到两个典型问题:一是页面强制重定向到 edit.php 列表页,二是 HTML 内容(如富文本邮件正文)在输出时被 WordPress 自动过滤或转义。根本原因在于 admin_post_{$action} 钩子默认不支持前端交互式响应,且非 AJAX 请求无法在保持当前编辑页上下文的同时完成异步处理。

推荐方案:采用 WordPress 原生 AJAX 机制
相比 admin-post.php 表单提交,AJAX 能实现无刷新操作、保留当前页面状态、精准控制请求/响应流程,并天然兼容 WordPress 的权限与 nonce 验证体系。

✅ 正确实现步骤

1. 后端注册 AJAX 处理函数(支持管理员权限)

// 在 functions.php 或插件主文件中
add_action('wp_ajax_quote_email_pdf', 'quote_email_pdf');

function quote_email_pdf() {
    // 必须验证用户权限(仅管理员可触发)
    if (!current_user_can('manage_options')) {
        wp_die('Insufficient permissions.');
    }

    // 可选:验证 nonce(需前端传入并在 JS 中生成)
    $nonce = isset($_POST['nonce']) ? sanitize_text_field($_POST['nonce']) : '';
    if (!wp_verify_nonce($nonce, 'send_quote_email_nonce')) {
        wp_die('Invalid security token.');
    }

    // 获取并清理前端传参
    $to       = sanitize_email($_POST['emailAddress'] ?? '');
    $full_name = sanitize_text_field($_POST['fullName'] ?? '');
    $subject  = "Quote from {$full_name}";
    $message  = "<h2>Hello {$full_name},</h2><p>Your quote is attached.</p><div class="aritcle_card flexRow">
                                                        <div class="artcardd flexRow">
                                                                <a class="aritcle_card_img" href="/ai/2120" title="Clipfly"><img
                                                                                src="https://img.php.cn/upload/ai_manual/000/000/000/175680175952892.png" alt="Clipfly"  onerror="this.onerror='';this.src='/static/lhimages/moren/morentu.png'" ></a>
                                                                <div class="aritcle_card_info flexColumn">
                                                                        <a href="/ai/2120" title="Clipfly">Clipfly</a>
                                                                        <p>一站式AI视频生成和编辑平台,提供多种AI视频处理、AI图像处理工具。</p>
                                                                </div>
                                                                <a href="/ai/2120" title="Clipfly" class="aritcle_card_btn flexRow flexcenter"><b></b><span>下载</span> </a>
                                                        </div>
                                                </div>";
    $headers  = array('Content-Type: text/html; charset=UTF-8');

    // 执行邮件发送
    $sent = wp_mail($to, $subject, $message, $headers);

    // 返回 JSON 响应(便于前端判断)
    wp_send_json([
        'success' => $sent,
        'message' => $sent ? 'Email sent successfully.' : 'Failed to send email.'
    ]);
}

2. 前端注册本地化脚本与事件绑定

确保在后台编辑页正确加载脚本并传递必要数据:

// 在 meta box 渲染函数中(或使用 add_meta_boxes 钩子)
function enqueue_quote_email_script($hook) {
    if ('post.php' !== $hook && 'post-new.php' !== $hook) {
        return;
    }
    if (get_post_type() !== 'quote') { // 替换为你的 CPT 名称
        return;
    }

    wp_enqueue_script('quote-email-js', plugin_dir_url(__FILE__) . 'js/quote-email.js', ['jquery'], '1.0', true);

    // 本地化 AJAX URL 和 nonce
    wp_localize_script('quote-email-js', 'sf_admin_ajax', [
        'sf_admin_ajax_url' => admin_url('admin-ajax.php'),
        'nonce'             => wp_create_nonce('send_quote_email_nonce')
    ]);
}
add_action('admin_enqueue_scripts', 'enqueue_quote_email_script');

3. 前端 JavaScript(quote-email.js)

jQuery(document).ready(function($) {
    const fullName = $('#quoteFullName').text().trim();
    const emailAddress = $('#quoteEmail a').text().trim();

    $('#downloadQuote').on('click', function(e) {
        e.preventDefault();

        // 禁用按钮防重复提交
        const $btn = $(this);
        $btn.prop('disabled', true).text('Sending...');

        $.post(sf_admin_ajax.sf_admin_ajax_url, {
            action: 'quote_email_pdf',
            emailAddress: emailAddress,
            fullName: fullName,
            nonce: sf_admin_ajax.nonce
        })
        .done(function(response) {
            if (response.success) {
                alert('✅ ' + response.data.message);
            } else {
                alert('❌ ' + (response.data.message || 'Unknown error.'));
            }
        })
        .fail(function(xhr, status, error) {
            console.error('AJAX Error:', error);
            alert('Network error. Please try again.');
        })
        .always(function() {
            $btn.prop('disabled', false).text('Send email');
        });
    });
});

4. HTML 按钮(置于 meta box 中)

<!-- 注意:无需 form 标签 -->
<button type="button" class="button button-primary" id="downloadQuote">Send email to customer</button>

⚠️ 关键注意事项

  • 权限校验不可省略:wp_ajax_{$action} 钩子对所有登录用户开放,务必用 current_user_can() 限制操作范围;
  • Nonce 验证增强安全性:虽非强制,但强烈建议加入,防止 CSRF 攻击;
  • 输入严格过滤:所有 $_POST 数据必须经 sanitize_*() 处理,尤其是邮箱地址(用 sanitize_email());
  • 错误处理要显式:wp_mail() 可能因 SMTP 配置失败而静默返回 false,需在前端给出明确反馈;
  • 避免 die() 或 echo 直接输出:AJAX 处理函数应统一使用 wp_send_json() 确保响应格式规范;
  • CPT 上下文识别:确保脚本仅在目标自定义文章类型的编辑页加载,提升性能与安全性。

通过以上结构化实现,你将获得一个稳定、安全、用户体验良好的后台邮件发送功能——既规避了传统表单的跳转缺陷,又充分利用了 WordPress 的安全基础设施。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
ajax教程
ajax教程

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

166

2023.06.14

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

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

170

2023.08.31

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

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

124

2023.11.15

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

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

253

2024.09.24

js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

530

2023.06.20

js获取当前时间
js获取当前时间

JS全称JavaScript,是一种具有函数优先的轻量级,解释型或即时编译型的编程语言;它是一种属于网络的高级脚本语言,主要用于Web,常用来为网页添加各式各样的动态功能。js怎么获取当前时间呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

554

2023.07.28

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

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

738

2023.08.03

js是什么意思
js是什么意思

JS是JavaScript的缩写,它是一种广泛应用于网页开发的脚本语言。JavaScript是一种解释性的、基于对象和事件驱动的编程语言,通常用于为网页增加交互性和动态性。它可以在网页上实现复杂的功能和效果,如表单验证、页面元素操作、动画效果、数据交互等。

6045

2023.08.17

JavaScript浏览器渲染机制与前端性能优化实践
JavaScript浏览器渲染机制与前端性能优化实践

本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。

23

2026.03.06

热门下载

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

精品课程

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

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