腾讯云服务器优惠活动华纳云香港服务器

WordPress修改更新文章后通知评论过那篇文章的用户

WordPress主题推荐

有时,有些文章出于某些原因,需要进行内容修改或代码更新等,如果是一些重要的更新修改,想让评论过的人知道此文章有修改更新,怎么办呢?!嘿嘿嘿,此文正是你所需要的!

WordPress修改更新文章后通知评论过那篇文章的用户-第1张-boke112百科(boke112.com)

功能描述: 在修改编辑文章的页面添加一个选项,只有勾选才会邮件通知,这样就不会每次修改频繁打扰到网友。

具体做法:将以下代码放到 functions.php 中:

  1. /**
  2.  * Wordpress修改更新文章后通知评论过那篇文章的用户 – 龙笑天下
  3.  * http://www.ilxtx.com/notify-comment-authors-when-the-post-is-updated.html
  4.  */
  5. //修改更新文章时邮件通知评论用户
  6. add_action( ‘submitpost_box’, ‘lxtx_fo_submit_box’);
  7. function lxtx_fo_submit_box( ){
  8. echo ‘<div id=“fo_side-sortables” class=“meta-box-sortables ui-sortable”>’;
  9. echo ‘<div id=“fo_submit_box” class=“postbox “>’;
  10. echo ‘<div class=“handlediv” title=“点击以切换”><br></div>’;
  11. echo ‘<h3 class=“hndle”><span>邮件通知</span></h3>’;
  12. echo ‘<div class=“inside”><div class=“submitbox”>’;
  13. echo ‘ <div style=“padding: 10px 10px 0;text-align: left;”><label class=“selectit” title=“慎用此功能,重要文章才勾选嘛,以免引起读者反感哈”><input type=“checkbox” name=“FO_emaill_report_user” value=“true” title=“勾选此项,将邮件通知本文所有评论者”/>邮通知本文所有评论者</label></div>’;
  14. echo ‘</div></div>’;
  15. echo ‘</div>’;
  16. echo ‘</div>’;
  17. }
  18. //开始
  19. add_action( ‘publish_post’, ‘lxtx_fo_emaill_report_users’ );
  20. function lxtx_fo_emaill_report_users($post_ID)
  21. {
  22. //如果未勾选保存,不进行任何操作
  23. if($_POST[‘FO_emaill_report_user’] != ‘true’){
  24. return;
  25. }
  26. //修订版本不通知,以免滥用
  27. if( wp_is_post_revision($post_ID) ){
  28. return;
  29. }
  30. //获取wp数据操作类
  31. global $wpdb,$post;
  32. // 读数据库,获取文章的所有用户的email并且不重复
  33. $emailauthor != ‘你自己的邮箱’;
  34. $wp_user_emails = $wpdb->get_results(“SELECT DISTINCT comment_author, comment_author_email FROM $wpdb->comments WHERE TRIM(comment_author_email) IS NOT NULL AND TRIM(comment_author_email) != ” AND TRIM(comment_author_email) != ‘$emailauthor’ AND comment_post_ID = $post->ID”);
  35. // 获取博客名称
  36. $blogname = wp_specialchars_decode(get_option(‘blogname’), ENT_QUOTES);
  37. // 获取博客URL
  38. $blogurl = get_bloginfo(“siteurl”);
  39. //文章链接
  40. $post_link = get_permalink($post_ID);
  41. //文章标题$post -> post_title
  42. $post_title = strip_tags($_POST[‘post_title’]);
  43. //文章内容$post->post_content
  44. $post_content = strip_tags($_POST[‘post_content’]);
  45. //文章摘要
  46. $output = preg_replace(‘/^(?:[\x00-\x7F]|[\xC0-\xFF][\x80-\xBF]+){0,0}((?:[\x00-\x7F]|[\xC0-\xFF][\x80-\xBF]+){0,200}).*/s’,’\1′,$post_content).‘……’;
  47. //邮件头,以免乱码
  48. $message_headers = “Content-Type: text/html; charset=\”utf-8\”\n”;
  49. // 邮件标题
  50. $subject = ‘您曾经来访过的《’.$post_title.’》文章更新通知。’;
  51. foreach ( $wp_user_emails as $wp_user_email )
  52. {
  53. // 邮件内容
  54. $message = ‘
  55. <div style=“MARGIN-RIGHT: auto; MARGIN-LEFT: auto;”>
  56. <strong style=“line-height: 1.5; font-family:Microsoft YaHei;”>
  57. 亲爱的’.$wp_user_email->comment_author.’:
  58. </strong>
  59. <p style=“FONT-SIZE: 14px; PADDING-TOP: 6px”>
  60. 您曾经来访过的《’.$post_title.’》有更新,博主觉得有必要通知您,希望不会骚扰到您。
  61. </p>
  62. <p style=“FONT-SIZE: 14px; PADDING-TOP: 6px”>
  63. 文章标题:<a title=“‘.$post_title.'” href=“‘.$post_link.'” target=“_top”>’.$post_title.'</a>
  64. <br/>
  65. 文章摘要:’.$output.’
  66. </p>
  67. <p style=“FONT-SIZE: 14px; PADDING-TOP: 6px”>
  68. 您可以点击链接
  69. <a href=“‘.$blogurl.'” style=“line-height: 1.5;”>’.$blogname.'</a>
  70. >
  71. <a title=“‘.$post_title.'” href=“‘.$post_link.'” target=“_top”>’.$post_title.'</a>
  72. 详细查看
  73. </p>
  74. <p style=“font-size: 14px; padding-top: 6px; text-align: left;”>
  75. <span style=“line-height: 1.5; color: rgb(153, 153, 153);”>
  76. 来自:
  77. </span>
  78. <a href=“‘.$blogurl.'” style=“line-height: 1.5;”>’.$blogname.'</a>
  79. </p>
  80. <div style=“font-size: 12px; border-top-color: rgb(204, 204, 204); border-top-width: 1px; border-top-style: solid; height: 35px; width: 500px; color: rgb(102, 102, 102); line-height: 35px; background-color: rgb(245, 245, 245);”>
  81. 该邮件为系统发送邮件,请勿直接回复!如有打扰,请向博主留言反映。灰常感谢您的阅读!
  82. </div>
  83. </div>’;
  84. wp_mail($wp_user_email->comment_author_email, $subject$message$message_headers);
  85. }
  86. }

—- 代码取自郑永博客

效果图如下:

WordPress修改更新文章后通知评论过那篇文章的用户-第2张-boke112百科(boke112.com)

友情提示

慎用此功能!

当然,邮件内容可以参考『纯代码实现WordPress评论回复邮件提醒功能及回复邮件样式美化教程』这篇文章来美化一下哦。

赞 (0) 打赏
版权声明:本文为投稿文章,感谢 龙笑天下 的投稿,版权归原作者所有!发布此文是出于传递更多信息之目的,若有来源标注错误或侵犯了您的合法权益,请联系我们,确认后马上更正或删除,谢谢!
wu