隐藏侧边栏

极简网页计数器 (site-counter)

 邱少羽梦
2022-01-10 / 9 评论 / 3 点赞 / 1,660 阅读 / 4,358 字 / 正在检测是否收录...
温馨提示:
本文最后更新于 2022-07-06,若内容或图片失效,请留言反馈。部分素材来自网络,若不小心影响到您的利益,请联系博主删除。

site-counter

介绍

这是一个极简网页计数器,功能和 busuanzi (不蒜子 - 极简网页计数器) 类似,比 busuanzi 功能更多,支持今日统计。

功能

  1. 累计站点总访问量(站点 pv)
  2. 累计站点总访客量(站点 uv)
  3. 累计站点今日访问量(站点今日 pv)
  4. 累计站点今日访客量(站点今日 uv)
  5. 累计站点某页面总访问量(站点页面 pv)
  6. 累计站点某页面总访客量(站点页面 uv)
  7. 累计站点某页面今日访问量(站点页面今日 pv)
  8. 累计站点某页面今日访客量(站点页面今日 uv)

快速上手

前端简易使用

  1. 引入 qiushaocloud_site_counter.min.js, 比如: <script async src="//githubcdn.qiushaocloud.top/gh/qiushaocloud/site-counter@master/dist/qiushaocloud_site_counter.min.js"></script>
  2. 界面中您根据您的需求,引入相应的节点元素 ID
    <p>总访问量: <span id="qiushaocloud_sitecounter_value_site_pv">n</span></p>
     <p>总访客量: <span id="qiushaocloud_sitecounter_value_site_uv">n</span></p>
     <p>今日访问量: <span id="qiushaocloud_sitecounter_value_today_site_pv">n</span></p>
     <p>今日访客量: <span id="qiushaocloud_sitecounter_value_today_site_uv">n</span></p>
   
     <p>本页面总访问量: <span id="qiushaocloud_sitecounter_value_site_page_pv">n</span></p>
     <p>本页面总访客量: <span id="qiushaocloud_sitecounter_value_site_page_uv">n</span></p>
     <p>本页面今日访问量: <span id="qiushaocloud_sitecounter_value_today_site_page_pv">n</span></p>
     <p> 本页面今日访客量: <span id="qiushaocloud_sitecounter_value_today_site_page_uv">n</span></p>

前端高级功能

  1. 设置访客 session 最大时长,默认 24h【例如您设置 1h, 那么 1h 内访客再次访问不算新访客,1h 后再访问则视为新访客,需要注意,无论设置多长时间,一旦跨天了,那么再次访问都是新访客】
    <script>
        window.localStorage.setItem('qiushaocloud_sitecounter_max_session_duration', 24 * 60 * 60 * 1000);
    </script>

    <script async src="//githubcdn.qiushaocloud.top/gh/qiushaocloud/site-counter@master/dist/qiushaocloud_site_counter.min.js"></script>
  1. 设置接口请求的服务器地址,设置后会以您设置的地址请求,不设置默认以 www.qiushaocloud.top 请求接口【注意:www.qiushaocloud.top 为个人搭建服务,不能确保接口请求没问题,建议您自己搭建服务器哦】
    <script>
        // 设置格式为:www.qiushaocloud.top 或者 https://www.qiushaocloud.top:443
        window.localStorage.setItem('qiushaocloud_sitecounter_api_host', 'www.qiushaocloud.top');
        //window.localStorage.setItem('qiushaocloud_sitecounter_api_host', 'https://www.qiushaocloud.top:443');
    </script>

    <script async src="//githubcdn.qiushaocloud.top/gh/qiushaocloud/site-counter@master/dist/qiushaocloud_site_counter.min.js"></script>
  1. 设置接口请求的签名secretKey, 当 qiushaocloud_site_counter.min.js 加载完成后会删除 window.QIUSHAOCLOUD_SITE_COUNTER_API_SIGN_SECRET_KEY
    <script>
        window.QIUSHAOCLOUD_SITE_COUNTER_API_SIGN_SECRET_KEY = '您需要设置的签名key';
    </script>
    
    <script async src="//githubcdn.qiushaocloud.top/gh/qiushaocloud/site-counter@master/dist/qiushaocloud_site_counter.min.js"></script>
  1. 设置页面ID,当需要统计页面 PV/UV, 但是您页面是通过地址栏参数来区分不同页面的(比如: https://yourAddr/yourPathname?page_id=xxx),您这时候就能用上此用法了
    <script>
        /**
         * 统计此界面时以 window.location.pathname + window.QIUSHAOCLOUD_SITE_COUNTER_PAGE_ID 进行统计
         * 例如您的地址: https://yourAddr/yourPathname?page_id=abc 和 https://yourAddr/yourPathname?page_id=def 表示两篇不同的文章
         * 您将 page_id 设置给 window.QIUSHAOCLOUD_SITE_COUNTER_PAGE_ID, 如: window.QIUSHAOCLOUD_SITE_COUNTER_PAGE_ID = `${page_id}`
         * 在统计时将以 ${yourPathname}+'adb' 以及 ${yourPathname}+'def' 分别对您这两篇文章进行统计
        **/
        window.QIUSHAOCLOUD_SITE_COUNTER_PAGE_ID = '您需要设置的页面ID';
    </script>
    
    <script async src="//githubcdn.qiushaocloud.top/gh/qiushaocloud/site-counter@master/dist/qiushaocloud_site_counter.min.js"></script>

不使用作者搭建的服务器,自己搭建服务器教程

打包发布 qiushaocloud_site_counter.js 和 qiushaocloud_site_counter.min.js

  1. 进入 site-counter 根目录
  2. 编辑 site-counter/web-js/.env,配置 YOUR_SERVER_HOST 和 API_SIGN_SECRET_KEY,YOUR_SERVER_HOST 为您服务器的地址,API_SIGN_SECRET_KEY 为您定义的签名 key
  3. 安装依赖: npm run yarn-install
  4. 打包: npm run build-dist
  5. 打包后在 site-counter/dist 下面就有 qiushaocloud_site_counter.js 和 qiushaocloud_site_counter.min.js

linux 环境下打包 docker 镜像【您可以不需要修改代码,可以直接拉取开源镜像: docker pull qiushaocloud/site-counter】

  1. 安装好 docker 环境
  2. 进入 site-counter 根目录
  3. 执行 ./build-docker.sh
  4. 等待镜像打包完成

宿主机运行 site-counter 服务

  1. 进入 site-counter 根目录
  2. 拷贝 env.tpl 为 .env, linux 命令: cp env.tpl .env
  3. 根据您的情况,修改 .env 文件
  4. 运行服务: npm run serve 或者 node app.js

Docker 运行 site-counter 服务

  1. 安装好 docker 和 docker-compose 环境
  2. 进入 site-counter 根目录
  3. 拷贝 env.tpl 为 .env, linux 命令: cp env.tpl .env
  4. 根据您的情况,修改 .env 文件
  5. 执行 ./run-docker.sh

参与贡献

  1. Fork 本仓库
  2. 新建 Feat_xxx 分支
  3. 提交代码
  4. 新建 Pull Request

开源不易,如果对您有帮助,请您动一动您的小手,给作者点 Star,也请您多多关注分享者「邱少羽梦

0

评论区