WordPress如何实现评论后可显示内容中附件下载地址

2022年1月24日09:45:051

最近在做一个项目的时候,有个需求就是希望WordPress网站文章内容里面附件可以评论后才可以下载。网络上面查了会,发现这个功能不难实现,写个简单的函数就可以了。而且这样也可以设置部分文章评论后可见。觉得这个功能应该挺多人有需要的,索性也就写一篇wordpress文章内容回复后可见的教程。

WordPress如何实现评论后可显示内容中附件下载地址

现在来说说如何实现wordpress的文章内容评论后可见吧?其实实现起来很简单,利用wordpress的短代码功能即可实现,代码如下:

function reply_to_read($atts, $content=null) {
    extract(shortcode_atts(array("notice" => '温馨提示: 此处内容需要评论本文后才能查看.'), $atts));
    $email = null;
    $user_ID = (int) wp_get_current_user()->ID;
    if ($user_ID > 0) {
      $email = get_userdata($user_ID)->user_email;
      //对博主直接显示内容
      $admin_email = "xxx@aaa.com"; //博主Email
      if ($email == $admin_email) {
        return $content;
      }
    } else if (isset($_COOKIE['comment_author_email_' . COOKIEHASH])) {
      $email = str_replace('%40', '@', $_COOKIE['comment_author_email_' . COOKIEHASH]);
    } else {
      return $notice;
    }
    if (empty($email)) {
      return $notice;
    }
    global $wpdb;
    $post_id = get_the_ID();
    $query = "SELECT `comment_ID` FROM {$wpdb->comments} WHERE `comment_post_ID`={$post_id} and `comment_approved`='1' and `comment_author_email`='{$email}' LIMIT 1";
    if ($wpdb->get_results($query)) {
      return do_shortcode($content);
    } else {
      return $notice;
    }
}
add_shortcode('reply', 'reply_to_read');

1.需要注意的是,要修改第8行的邮件为管理员的。如果你的网站使用了ajax免刷新提交评论,应该还需要修改第2行的提示文字,提示访客评论后刷新页面来查看隐藏内容。

2.编辑文章时,使用下面的简码:

【reply】评论可见的内容【/reply】

或者

【reply notice="自定义的提示信息"】评论可见的内容【/reply】

希望本文所述对大家基于wordpress的程序设计有所帮助。

WordPress主题如何将侧边滚动条变成彩色 WordPress

WordPress主题如何将侧边滚动条变成彩色

WordPress默认的浏览器侧边栏翻滚条是十分丑恶的,当然,有些WordPress主题是自带美化的侧边翻滚栏不需要咱们自己去美化,有些WordPress主题是没有美化侧边翻滚栏的,那么这时就需要咱们...
WordPress实现和本地电脑对接Contabo对象存储 WordPress

WordPress实现和本地电脑对接Contabo对象存储

这是我第一次用国外的对象存储,综合对比了下选择了contabo家,不过由于他们家是新出来的,目前功能比较弱,地区也少,还默认走的cloudflare cdn,所以如果用户主要是面向国内的还是多考虑下吧...
WordPress如何获取文章顶级分类的目录信息 WordPress

WordPress如何获取文章顶级分类的目录信息

因为 WordPress 数据库结构设计的原因,有时候就级别多一点就需要循环了获取,如果分类目录层级多了,要想获取到顶级目录的信息还真的需要折腾一下,而且也查询过 WordPress 并没有提供相关的...
匿名

发表评论

匿名网友 填写信息

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

评论:1   其中:访客  0   博主  1
    • 星光 星光

      爱爱爱