前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Hexo添加当前访客信息

Hexo添加当前访客信息

作者头像
花猪
发布2022-02-22 17:06:33
9870
发布2022-02-22 17:06:33
举报
文章被收录于专栏:花猪的学习记录

前言

本文将介绍如何在主页侧边栏添加当前访客信息,具体效果如下:

教程链接:Hexo博客搭建 与 美化教程 | 卓越科技的Blog (zykj.js.org)

操作

注意:必须确保使用了Hexo tag 外挂标签span的样式(👈点击跳转),否则显示的内容没有彩色样式。

1.在 themes\Butterfly\layout\includes\widget\ 下创建 card_ip.pug 文件,并写入以下内容:

代码语言:javascript
复制
.card-widget.card-ip
  .card-content
  .item-headline
    i.fa.fa-user(aria-hidden="true")
    span= _p('aside.card_ip')
  .ip_content
   = _p('欢迎来自 ')
   span(class="p red")= _p('未知区域')
   = _p(' 的小伙伴')
   b
   = _p('访问IP为: ')
   span(class="p cyan")= _p('未知IP')
   b
   = _p('浏览器版本:')
   span(class="p blue")= _p('未知浏览器')

2.在 themes\Butterfly\layout\includes\widget\index.pug中添加如下内容:

如果主题版本小于3.6,添加如下内容

代码语言:javascript
复制
if theme.aside.card_ip
    !=partial('includes/widget/card_ip', {}, {cache: theme.fragment_cache})

如果主题版本大于3.6,添加如下内容

代码语言:javascript
复制
if theme.aside.card_ip
    !=partial('includes/widget/card_ip', {}, { cache:true })

具体添加位置如下图所示:

3.编辑 themes\Butterfly\languages\zh-CN.yml 文件,在 aside 处添加card_ip: 当前访问用户代码(如下):

代码语言:javascript
复制
aside:
  card_ip: 当前访问用户

4.配置主题文件_config.butterfly.yml,在aside 处添加card_ip: true代码(如下):

代码语言:javascript
复制
aside:
  card_ip: true

5.在 themes\Butterfly\source\js 下创建 ip_content.js,并添加如下内容:

代码语言:javascript
复制
//获取当前IP地址和浏览器标识
function getBrowserInfo() {
    var agent = navigator.userAgent.toLowerCase();

    var regStr_ie = /msie [\d.]+;/gi;
    var regStr_ff = /firefox\/[\d.]+/gi
    var regStr_chrome = /chrome\/[\d.]+/gi;
    var regStr_saf = /safari\/[\d.]+/gi;

    //IE
    if (agent.indexOf("msie") > 0) {
        return agent.match(regStr_ie);
    }

    //firefox
    if (agent.indexOf("firefox") > 0) {
        return agent.match(regStr_ff);
    }

    //Chrome
    if (agent.indexOf("chrome") > 0) {
        return agent.match(regStr_chrome);
    }

    //Safari
    if (agent.indexOf("safari") > 0 && agent.indexOf("chrome") < 0) {
        return agent.match(regStr_saf);
    }
}

var ip_content = document.querySelector(".ip_content");

if (ip_content != null && typeof (returnCitySN) != undefined) {
    ip_content.innerHTML = '欢迎来自 <span class="p red">' + returnCitySN["cname"] + "</span> 的小伙伴<br>" + "访问IP为: <span class='p cyan'>" + returnCitySN["cip"] + "</span><br>浏览器版本:<span class='p blue'>" + getBrowserInfo() + '</span>';
}

6.配置主题文件_config.butterfly.yml,在inject的bottom处引入以下内容:

代码语言:javascript
复制
bottom:
  - <script src="https://pv.sohu.com/cityjson?ie=utf-8"></script>
  - <script src="/js/ip_content.js"></script>

7.至此完成配置,重新部署博客看看效果吧。

后记

ip位置通过访问:https://pv.sohu.com/cityjson?ie=utf-8 获得。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021-05-28,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 前言
  • 操作
  • 后记
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档