文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

WordPress评论邮件通知无插件实现思路及代码

2022-06-12 02:05

关注

通常我们喜欢使用Wordpress Thread Comment 或 Mail To Commenter这两款插件前者久未更新,已测支持WordPress2.9.2版本 其他的未测试,优点,不进垃圾箱,支持嵌套回复。

后者据网友反馈 该插件容易造成邮件延迟 邮件进垃圾箱或收不到邮件的情况。

今天来通过无插件实现WordPress评论邮件通知,先看效果:

方法:在主题目录的functions中增加以下代码:


复制代码代码如下:

function comment_mail_notify($comment_id) {

$admin_email = get_bloginfo ('admin_email'); // $admin_email 可改為你指定的 e-mail.

$comment = get_comment($comment_id);

$comment_author_email = trim($comment->comment_author_email);

$parent_id = $comment->comment_parent ? $comment->comment_parent : '';

$to = $parent_id ? trim(get_comment($parent_id)->comment_author_email) : '';

$spam_confirmed = $comment->comment_approved;

if (($parent_id != '') && ($spam_confirmed != 'spam') && ($to != $admin_email) && ($comment_author_email == $admin_email)) {

$wp_email = 'no-reply@' . preg_replace('#^www\.#', '', strtolower($_SERVER['SERVER_NAME'])); // e-mail 發出點, no-reply 可改為可用的 e-mail.

$subject = '您在【' . get_option("blogname") . '】的留言有回复了!去看看吧 ^_^';

$message = '

<div style="margin: 1em 40px 1em 40px;background-color:#eef2fa;border:1px solid #d8e3e8;color:#111;padding: 0 15px;-moz-border-radius:5px;-webkit-border-radius:5px;-khtml-border-radius:5px;border-radius:5px;">

<p>Hi !<strong>' . trim(get_comment($parent_id)->comment_author) . '</strong>,您好!

您曾在<strong>《' . get_the_title($comment->comment_post_ID) . '》</strong>的留言有了新回复。</p></div>

<div style="margin: 1em 40px 1em 40px;background-color:#eef2fa;border:1px solid #d8e3e8;color:#111;padding: 0 15px;-moz-border-radius:5px;-webkit-border-radius:5px;-khtml-border-radius:5px;border-radius:5px;"><p><strong>

您</strong>说:' . trim(get_comment($parent_id)->comment_content) . '</p>

<p><strong>' . trim($comment->comment_author) . '</strong>说:

' . trim($comment->comment_content) . '</p>

<p>您可以点击<a href="' . htmlspecialchars(get_comment_link($parent_id)) . '">查看完整的回复內容。</a></p>

<p>欢迎再度光临 <a href="' . get_option('home') . '">' . get_option('blogname') . '</a></p>

<p>(此邮件由系统自动发送,请勿回复。)</p></div>

';

$from = "From: \"" . get_option('blogname') . "\" <$wp_email>";

$headers = "$from\nContent-Type: text/html; charset=" . get_option('blog_charset') . "\n";

wp_mail( $to, $subject, $message, $headers );

echo 'mail to ', $to, '

' , $subject, $message; // for testing

}

}

add_action('comment_post', 'comment_mail_notify');

// -- END ----------------------------------------

已测试 兼容WordPress3.1版本及多款主题。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-开源
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯