更新WordPress文章通知评论过的用户

我们使用WordPress建站时,时常会宣布一些代码类、连续更新类的文章,那么会有存在更新和追加的情形,这样的话我们需要通知那些谈论过这篇文章这的用户呢。这段代码就是实现在文章有修改或更新时刻可以决议是否邮件通知对这篇文章有谈论的访客。若是对一些类似的旧文章举行更新,而这种更新一旦没有实时通知感兴趣的同伙,往往就没有什么意义了。那么怎么存代码实现更新WordPress文章通知谈论过的用户呢?我们需要添加相关代码后会在修改编辑文章的页面添加一个选项,勾选这个选项才会邮件通知谈论过的用户,这样可以显著减轻回复的压力,只有勾选才会邮件通知,这样就不会每次修改频仍打扰到网友。

实现方式:

将以下代码放到 functions.php 中:

  1. /**
  2.  * WordPress 修改更新文章后邮件通知谈论过那篇文章的用户
  3.  */
  4. //修改更新文章时邮件通知谈论用户
  5. add_action( 'submitpost_box', 'lxtx_fo_submit_box');
  6. function lxtx_fo_submit_box( ){
  7. echo '<div id="fo_side-sortables" class="meta-box-sortables ui-sortable">';
  8. echo '<div id="fo_submit_box" class="postbox ">';
  9. echo '<div class="handlediv" title="点击以切换"><br></div>';
  10. echo '<h3 class="hndle"><span>邮件通知</span></h3>';
  11. echo '<div class="inside"><div class="submitbox">';
  12. 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>';
  13. echo '</div></div>';
  14. echo '</div>';
  15. echo '</div>';
  16. }
  17. //最先
  18. add_action( 'publish_post', 'lxtx_fo_emaill_report_users' );
  19. function lxtx_fo_emaill_report_users($post_ID)
  20. {
  21. //若是未勾选保留,不举行任何操作
  22. if($_POST['FO_emaill_report_user'] != 'true'){
  23. return;
  24. }
  25.  
  26. //修订版本不通知,以免滥用
  27. if( wp_is_post_revision($post_ID) ){
  28. return;
  29. }
  30.  
  31. //获取wp数据操作类
  32. global $wpdb,$post;
  33. // 读数据库,获取文章的所有用户的email而且不重复
  34. $emailauthor != '你自己的邮箱';
  35. $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");
  36.  
  37. // 获取博客名称
  38. $blogname = wp_specialchars_decode(get_option('blogname'), ENT_QUOTES);
  39. // 获取博客URL
  40. $blogurl = get_bloginfo("siteurl");
  41.  
  42. //文章链接
  43. $post_link = get_permalink($post_ID);
  44. //文章题目$post -> post_title
  45. $post_title = strip_tags($_POST['post_title']);
  46. //文章内容$post->post_content
  47. $post_content = strip_tags($_POST['post_content']);
  48. //文章摘要
  49. $output = preg_replace('/^(?:[\x00-\x7F]|[\xC0-\xFF][\x80-\xBF]+){0,0}((?:[\x00-\x7F]|[\xC0-\xFF][\x80-\xBF]+){0,200}).*/s','\1',$post_content).'......';
  50.  
  51. //邮件头,以免乱码
  52. $message_headers = "Content-Type: text/html; charset=\"utf-8\"\n";
  53. // 邮件题目
  54. $subject = '您曾经来访过的《'.$post_title.'》文章更新通知。';
  55.  
  56. foreach ( $wp_user_emails as $wp_user_email )
  57. {
  58. // 邮件内容
  59. $message = '
  60. <div style="MARGIN-RIGHT: auto; MARGIN-LEFT: auto;">
  61. <strong style="line-height: 1.5; font-family:Microsoft YaHei;">
  62. 亲爱的'.$wp_user_email->comment_author.':
  63. </strong>
  64. <p style="FONT-SIZE: 14px; PADDING-TOP: 6px">
  65. 您曾经来访过的《'.$post_title.'》有更新,博主以为有需要通知您,希望不会骚扰到您。
  66. </p>
  67. <p style="FONT-SIZE: 14px; PADDING-TOP: 6px">
  68. 文章题目:<a title="'.$post_title.'" href="'.$post_link.'" rel="external nofollow"  rel="external nofollow"  target="_top">'.$post_title.'</a>
  69. <br/>
  70. 文章摘要:'.$output.'
  71. </p>
  72. <p style="FONT-SIZE: 14px; PADDING-TOP: 6px">
  73. 您可以点击链接
  74. <a href="'.$blogurl.'" rel="external nofollow"  rel="external nofollow"  style="line-height: 1.5;">'.$blogname.'</a>
  75. >
  76. <a title="'.$post_title.'" href="'.$post_link.'" rel="external nofollow"  rel="external nofollow"  target="_top">'.$post_title.'</a>
  77. 详细查看
  78. </p>
  79. <p style="font-size: 14px; padding-top: 6px; text-align: left;">
  80. <span style="line-height: 1.5; color: rgb(153, 153, 153);">
  81. 来自:
  82. </span>
  83. <a href="'.$blogurl.'" rel="external nofollow"  rel="external nofollow"  style="line-height: 1.5;">'.$blogname.'</a>
  84. </p>
  85. <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);">
  86. 该邮件为系统发送邮件,请勿直接回复!若有打扰,请向博主留言反映。灰常谢谢您的阅读!
  87. </div>
  88. </div>';
  89. wp_mail($wp_user_email->comment_author_email, $subject, $message, $message_headers);
  90. }
  91. }

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

1. 本站所有资源来源于用户上传和网络,因此不包含技术服务请大家谅解!如有侵权请邮件联系客服!3308869544
2. 本站不保证所提供下载的资源的准确性、安全性和完整性,资源仅供下载学习之用!如有链接无法下载、失效或广告,请联系客服处理,有奖励!
3. 您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容资源!如用于商业或者非法用途,与本站无关,一切后果请用户自负!
4. 如果您也有好的资源或教程,您可以投稿发布,成功分享后有猫币奖励和额外收入!

主题镇 WP教程 更新WordPress文章通知评论过的用户 https://zhutizhen.com/14533.html

永远为用户服务的镇长!

常见问题
  • 本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。
查看详情
  • 最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或联络我们。
查看详情

相关文章