Umami 是一个开源网页访问统计服务,类似Google Analytics。专注于简单,快速,隐私安全。相对于把数据交给大公司,收到各种各样的限制,各种付费解锁功能,自建访问统计,自己掌握访问统计数据更好!还可以统计网页的PV, UV,功能定制化更高!
Umami 统计
安装
创建下面这些文件
Umami UV / PV 统计显示
Umami 统计了 UV PV 等各种访问数据,比不蒜子详细得多,自建服务也比不蒜子稳定。那么怎么用 Umami 代替不蒜子了? 下文将介绍详细方法
新建 View only
权限的用户
Q: 为什么不直接调用 Umami 的 API 获取数据,而是要额外创建一个账户?
A: 博客是 静态开源无服务器 的,所有代码都展示在前端,包括 API 调用。而 Umami 的
admin
API 权限太大了,如果使用admin
权限的 API Token,那么这个 token 可以获取、修改、删除所有网站的数据,会有严重的安全隐患。所以我们需要创建一个
View only
权限的用户,使用这个低权限的用户
的 API Token 来访问我们的浏览量等数据。
新建 Team
并添加用户和网站
Settings
-> Teams
-> Create team
-> 填写名称 -> Save
-> 找到刚刚创建的 Team
-> Edit
-> 复制 Access code
,点击 Websites
中点击 Add website
选中你想共享的网站
换一个浏览器登录 Umami(使用View only
权限的用户) -> Settings
-> Teams
-> Join team
-> 输入 Access code
-> Join
-> 如果没有出错的话,点击 Dashboard
就可以看到你刚刚添加的网站了
获取 View only
用户的 API Token
根据 Umami 的文档,我们可以通过以下方式获取 API Token:
例如 你的网站地址为 example.com
,那么你需要使用 View only
的账户密码向 https://example.com/api/auth/login
发送一个 POST 请求,请求体为:
如果成功,你应该会得到以下的结果:
保存 token 值,并在所有请求中发送带 Bearer <token>
值的 Authorization
标头。请求标头应该如下所示:
发送请求获取数据
这里要用到类似于 postman
的 API 测试工具,可以使用的是开源的 hoppscotch,你也可以使用 curl
或者其他工具。
先分析一下官方文档的 API 接口:GET /api/websites/{websiteId}/stats
有两个必填的 查询参数:startAt
和 endAt
,都是 Unix 毫秒时间戳,表示开始时间和结束时间
websiteId
和 startAt
需要我们自己获取
websiteId
可以在 Dashboard
-> View details
-> 看浏览器栏的地址 https://example.com/websites/{websiteId}
中找到
startAt
可发送 GET
请求到 https://example.com/api/websites/{websiteId}
,请求头为
在返回结果中找到 createdAt
字段,这个字段就是 startAt
的值,也就是你的网站创建时间,数据的开始时间
编写页面
代码如下,修改你对应的参数即可运行:
参考&致谢
- umami-software/umami: Umami is a simple, fast, privacy-focused alternative to Google Analytics.
- Umami UV / PV 统计显示
- https://umami.is/docs/websites-api
- https://umami.is/docs/authentication
- https://umami.is/docs/website-stats
雷打真孝子,财发狠心,麻绳专挑细处断,恶运专找苦命人!
——俗语赏析
系列教程
Hexo系列
[三万字教程]基于Hexo的matery主题搭建博客并深度优化完全一站式教程
- Hexo Docker环境与Hexo基础配置篇
- hexo博客自定义修改篇
- hexo博客网络优化篇
- hexo博客增强部署篇
- hexo博客个性定制篇
- hexo博客常见问题篇
- hexo博客博文撰写篇之完美笔记大攻略终极完全版
- Hexo Markdown以及各种插件功能测试
- markdown 各种其它语法插件,latex公式支持,mermaid图表,plant uml图表,URL卡片,bilibili卡片,github卡片,豆瓣卡片,插入音乐和视频,插入脑图,插入PDF,嵌入iframe
- 在 Hexo 博客中插入 ECharts 动态图表
- 使用nodeppt给hexo博客嵌入PPT演示
- GithubProfile美化与自动获取RSS文章教程
- Vercel部署高级用法教程
- webhook部署Hexo静态博客指南
- 在宝塔VPS上面采用docker部署waline全流程图解教程
- 自建Umami访问统计服务并统计静态博客UV/PV
Docker系列
- Docker使用简明教程
- 使用jeckett,sonarr,iyuu,qt,emby打造全自动追剧流程
- 为知笔记私有化Docker部署
- Earthly 一个更加强大的镜像构建工具
- 使用 Shell 脚本实现一个简单 Docker
- 如何使用Traefik V2 在Ubuntu20.04 上面来做 Dockers
- 通过IPV6访问Qnap NAS中Docker的服务
笔记系列
- 完美笔记进化论
- hexo博客博文撰写篇之完美笔记大攻略终极完全版
- Joplin入门指南&实践方案
- 替代Evernote免费开源笔记Joplin-网盘同步笔记历史版本Markdown可视化
- Joplin 插件以及其Markdown语法。All in One!
- Joplin 插件使用推荐
- 为知笔记私有化Docker部署
Gitbook使用系列
- GitBook+GitLab撰写发布技术文档-Part1:GitBook篇
- GitBook+GitLab撰写发布技术文档-Part2:GitLab篇
- 自己动手制作电子书的最佳方式(支持PDF、ePub、mobi等格式)