如何制作WordPress侧边栏站点统计信息小工具

2020年10月22日16:05:24 发表评论 2,091 ℃

WordPress有些模板没有站点统计信息小工具,比如统计网站浏览次数、文章总数等等信息。

如果要实现这个功能,1、换一些有此功能的模板。2、自己动手添加一个。

如果本身对模板已经二次修改,再去更换模板那就比较繁琐了。

接下来阿汤博客就分享下方案二,自己动手添加一个侧边栏站点统计信息小工具。

1、新建一个php文件,并将以下代码添加到tongji.php文件中。

<?php
// 站点统计小工具
//  阿汤博客 www.amd5.cn
// 定义小工具的类 EfanBlogStat
class EfanBlogStat extends WP_Widget{
    function EfanBlogStat(){
        // 定义小工具的构造函数
        // 注意classname,这里的widget_tongji要在style.css存在此样式,也可以自己定义。
        $widget_ops = array('classname' => 'widget_tongji', 'description' => '显示站点的统计信息');
        $this->WP_Widget(false, '站点统计', $widget_ops);
    }
    function form($instance){
        // 表单函数,控制后台显示
        // $instance 为之前保存过的数据
        // 如果之前没有数据的话,设置默认量
        $instance = wp_parse_args(
            (array)$instance,
            array(
                'title' => '站点统计',
                'establish_time' => '2018-01-01'
            )
        );
        $title = htmlspecialchars($instance['title']);
        $establish_time = htmlspecialchars($instance['establish_time']);
        // 表格布局输出表单
        $output = '<table>';
        $output .= '<tr><td>标题</td><td>';
        $output .= '<input id="'.$this->get_field_id('title') .'" name="'.$this->get_field_name('title').'" type="text" value="'.$instance['title'].'" />';
        $output .= '</td></tr><tr><td>建站日期:</td><td>';
        $output .= '<input id="'.$this->get_field_id('establish_time') .'" name="'.$this->get_field_name('establish_time').'" type="text" value="'.$instance['establish_time'].'" />';
        $output .= '</td></tr></table>';
        echo $output;
    }
    function update($new_instance, $old_instance){
        // 更新数据的函数
        $instance = $old_instance;
        // 数据处理
        $instance['title'] = strip_tags(stripslashes($new_instance['title']));
        $instance['establish_time'] = strip_tags(stripslashes($new_instance['establish_time']));
        return $instance;
    }
    function widget($args, $instance){
        extract($args); //展开数组
        $title = apply_filters('widget_title',empty($instance['title']) ? '&nbsp;' : $instance['title']);
        $establish_time = empty($instance['establish_time']) ? '2018-01-01' : $instance['establish_time'];
        echo $before_widget;
        echo $before_title . $title . $after_title;
        echo '<ul>';
        // $this->efan_get_blogstat($establish_time, $instance);
        $this->efan_get_blogstat($establish_time);
        echo '</ul>';
        echo $after_widget;
    }
    function efan_get_blogstat($establish_time /*, $instance */){
        // 相关数据的获取
        global $wpdb;
        $count_posts = wp_count_posts();
        $published_posts = $count_posts->publish;
        $comments_count = $wpdb->get_var("SELECT COUNT(*) FROM $wpdb->comments");
        $time = floor((time()-strtotime($establish_time))/86400);
        $count_tags = wp_count_terms('post_tag');
        $count_pages = wp_count_posts('page');
        $page_posts = $count_pages->publish;
        $count_categories = wp_count_terms('category');
        $link = $wpdb->get_var("SELECT COUNT(*) FROM $wpdb->links WHERE link_visible = 'Y'");
        $last = $wpdb->get_results("SELECT MAX(post_modified) AS MAX_m FROM $wpdb->posts WHERE (post_type = 'post' OR post_type = 'page') AND (post_status = 'publish' OR post_status = 'private')");
        $last = date('Y-n-j', strtotime($last[0]->MAX_m));
        $total_views = $wpdb->get_var("SELECT SUM(meta_value+0) FROM $wpdb->postmeta WHERE meta_key = 'views'");
        // 显示数据
        $output = '<li>文章总数:</li><li>';
        $output .= $published_posts;
        $output .= ' 篇</li>';
        $output .= '<li>留言数量:</li><li>';
        $output .= $comments_count;
        $output .= ' 条</li>';
        $output .= '<li>页面总数:</li><li>';
        $output .= $page_posts;
        $output .= ' 个</li>';
        $output .= '<li>分类总数:</li><li>';
        $output .= $count_categories;
        $output .= ' 个</li>';
        $output .= '<li>标签总数:</li><li>';
        $output .= $count_tags;
        $output .= ' 个</li>';
        $output .= '<li>友链总数:</li><li>';
        $output .= $link;
        $output .= ' 个</li>';
        $output .= '<li>浏览总量:</li><li>';
        $output .= $total_views;
        $output .= ' 次</li>';
        $output .= '<li>建站日期:</li><li>';
        $output .= $establish_time;
        $output .= '</li>';
        $output .= '<li>运行天数:</li><li>';
        $output .= $time;
        $output .= ' 天</li>';
        $output .= '<li>最后更新:</li><li>';
        $output .= $last;
        $output .= '</li>';
        echo $output;
    }
}
function EfanBlogStat(){
    // 注册小工具
    register_widget('EfanBlogStat');
}
add_action('widgets_init','EfanBlogStat');
?>

2、将tongji.php上传到/wp-content/themes/模板名称/目录下面,然后修改/wp-content/themes/模板名称/functions.php文件,在此文件的末尾 “?>”之前加上如下代码。

//添加站点统计小工具文件
include("tongji.php");

3、自定义样式,将下面的样式添加到/wp-content/themes/模板名称/style.css文件的末尾。

.widget_tongji ul{padding:5px 0 15px 20px;color:#00a67c;width: 94%}
.widget_tongji li{width:42%;background-color:#fff;padding:5px 8px;display:inline-block;border:solid 1px #dddd;}

注:样式名称widget_tongji要和tongji.php里面的classname对应的值一致,样式可以根据自己的模板进行修改。

4、登录WordPress后台,外观->小工具 找到 “站点统计”小工具,然后添加到想要的位置。

最终阿汤博客的显示效果,如下图:

如何制作WordPress侧边栏站点统计信息小工具

如果需要添加侧边栏微信二维码联系方式,可以参考文章:《如何在WordPress侧边栏添加微信二维码联系方式

【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中

发表评论

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