网站建设

WordPress显示访客UA信息:Show UserAgent纯代码轻度汉化版

Jager · 1月10日 · 2015年 8750次已读

前几天在修复留言日期显示错误的问题时,突然觉得可以在这个位置集成一下访客信息,因为见到过不少博客的留言板都有了类似的功能。经过搜索、测试并筛选,最终选定了 Show UserAgent 这款插件。在本地测试了一下,感觉还不错!

一、强迫症

在我熟悉了 WordPress 插件机制后,我总是强迫症的想将插件修改为代码集成。实际上插件和代码的差别只在于代码不需要用到一些钩子动作(hook action)和选项数据(option data)。很多人说插件用多了会拖慢速度,没错是有这么回事,但是如果你把同样数量的插件修改成纯代码集成,我想速度也不会快多少!你以为增加的功能是吃白饭的哦?多一个功能就多会一份消耗!

那修改为代码版是为了提升性能嘛?其实也不尽然,我这种强迫症会这样想:看到后台已安装插件黑压压的,就会抓耳挠腮,想尽办法能删一个是一个。所以,我拿到这个插件并测试无误后,第一件时间就是将其修改为代码版,以满足强迫症的心理需求。

二、折腾狂

经过几番折腾,目前已趋近完善:

①、合并 php 代码并去掉了插件所需的冗余代码,如 hook、action 等;

②、轻度汉化了一些信息显示(浏览器名称,部分国籍等),插件是纯英文的;

③、创意性添加诙谐翻译(原创诙谐翻译,请勿盗版哟~哈哈):

WordPress显示访客UA信息:Show UserAgent纯代码轻度汉化版 WordPress显示访客UA信息:Show UserAgent纯代码轻度汉化版 WordPress显示访客UA信息:Show UserAgent纯代码轻度汉化版

④、其他不为人知的折腾细节。

三、自己撸

下面分享部署方法,自己撸去吧:

①、下载我整理好的代码包:

②、解压后将得到的 show-useragent 文件夹一并上传到正在用的 WordPress 主题目录;

③、编辑 WordPress 主题目录下的 functions.php,在第一个<?php 之后或最后一个 ?>之前添加引用语句:

include("show-useragent/show-useragent.php");  //显示访客信息

④、下面这一步有点麻烦,请仔细看;

A. 编辑 WordPress 主题目录下的 comments.php 文件,搜索 wp_list_comments:

比如,知更鸟 HotNewspro 的 comments.php 文件会搜到下面这一串代码

<?php wp_list_comments('type=comment&callback=mytheme_comment&end-callback=mytheme_end_comment'); ?>

如果你发现代码中有一个 callback=xxxxx 回调函数,那么说明你的主题已自定义了评论列表的样式,那么请自行查找 callback 后面接的函数名(一般会在主题目录下的 functions.php 里面),然后在适当的位置插入如下代码:

<?php CID_print_comment_flag(); echo ' ';CID_print_comment_browser(); ?>

比如张戈博客,就是将以上代码添加到了评论者名称的后面,所以我只要在 mytheme_comment 函数里面找到评论者评论代码:

<strong><?php commentauthor(); ?></strong>:

然后在后面添加 UA 显示代码,添加后如下所示:

<strong><?php commentauthor(); ?></strong>:
<?php CID_print_comment_flag(); echo ' ';CID_print_comment_browser(); ?>

B. 如果主题没有自定义评论样式,那就得对 WP 动刀子了,这种情况比较少,本文就不赘述了。

顺便说一下,评论列表这个函数(wp_list_comments)位于 wp-includes/comment-template.php,主题没有自定义评论列表的话,自己去看着文件,慢慢折腾吧!

个人建议,如果主题没有自定义评论主题列表,还是自行定义一个比较好,网上教程也挺多,搜索 mytheme_comment 应该就能找到一大把,自己去折腾吧!

四、补刀手

萝卜白菜,各有所爱!每个人都有自己不同的口味,所以简单说一下拿到代码后如何继续自定义修改。

其实,被我合并代码之后,能修改的基本都一目了然,会中文并能认识简单的一些英文,什么 Windows,MAC OS 啥的。那你就可以自定转换为你想要的中文显示。

基本上,能修改的内容都在合并后的文件里面:show-useragent.php

比如,我把插件定义的 China 临时修改为【来自天朝的朋友】,我只需要找到合理的位置,插入如下代码:

if($name=='China'){
    $name = '来自天朝的朋友';
}

当然了,既然你要继续折腾,那你也总得有点基础,别瞎改代码,回头变白板了就来我这投诉我给的东西不能用啥的!喜欢折腾,不会代码,还不爱搜索的人,还是安心写文章吧,别整这些“没用的”!

五、新补充

IP 库更新的方法:http://www.speedfly.cn/9488.html

最新 IP 库下载:https://zhang.ge/wp-content/themes/HotNewspro/show-useragent/ip2c/ip-to-country.bin

下载后替换插件下同名文件即可。

42 条回应
  1. 七支剑 2015-1-10 · 12:44

    终于等到了 国际惯例先留后看

  2. 心音乐 2015-1-10 · 16:33

    要是能放到多说里就好了,虽然有人弄出来相似的代码,但是样式实在太丑了。

    • 同盟源 2015-1-11 · 0:24

      去看看我的,我就是多说

  3. jayroof 2015-1-10 · 17:22

    已成功使用,谢谢。

  4. 易淘金 2015-1-10 · 20:43

    谢谢分享····················

  5. 同盟源 2015-1-11 · 0:23

    早就改了 :arrow:

    • avatar
      Jager 2015-1-11 · 7:59

      :evil: 好像很厉害似的,你是改的这个?还早就改了。。。

    • 同盟源 2015-1-11 · 10:18

      我把多说js本地化了,JS里面改的,CSS也本地化了,现在不用担心多说服务器抽风了

      • avatar
        Jager 2015-1-11 · 10:59

        多说服务器要是真抽风,本地化也没用的,毕竟数据在人家服务器,服务器抽风,数据跟着受影响。

  6. 灰常记忆 2015-1-11 · 14:09

    太有强迫症了 来自天朝的朋友

  7. 小武 2015-1-12 · 11:12

    为【来自天朝的朋友】点32个赞. .实在是太有创意了. . :wink:

  8. avatar
    Jager 2015-1-12 · 16:38

    兄弟,写到functions和include是一样的道理,而且推荐把自定义功能分离到其他文件,然后include,便于升级主题啥的。

  9. 大锅先森 2015-1-12 · 22:01

    这插件,太臃肿了,对国内来说有很多没用的系统和浏览器。博主最好删除了添加本土的几个浏览器

    • avatar
      Jager 2015-1-12 · 22:27

      本土的好像都已经集成了,其他不常用的确实可以清理下,省去不必要的判断。

      • 大锅先森 2015-1-12 · 22:35

        ie11、360极速没有,还有淘宝、猎豹、百度、qq这些垃圾浏览器要不要加了呢

        • avatar
          Jager 2015-1-13 · 9:00

          :???: 有时间再说吧。

  10. 瑾瑜 2015-1-15 · 23:27

    哈哈,诙谐翻译不错。张哥分享东西,总会有自己的一些改进。

  11. 大肥羊 2015-2-6 · 13:31

    貌似没有更新插件带的 IP 库,有些新 IP 会显示不出来。

  12. 幻杀博客 2015-2-28 · 15:00

    你对WP动刀子,我要对多说动刀子了,我现在用的不能显示IP……多说的js改成php会是啥感觉…… :grin:

    • 西门飘雪 2017-7-28 · 16:26

      亲,我现在也遇到类似的要动刀子的问题了!感谢帮忙分析一下,给个解决之道。非常感谢!我这里看到您这边显示的地址很具体。所以膜拜您为师,学习学习!

  13. 替替 2015-4-5 · 3:07

    非常感谢博主,我用的Ality主题也已经设置成功,第二步查找“callback后面接的函数名”没有找到,但我发现如下图线索:查找函数的发现,随后在/inc/functions/comment-template.php这个目录下找到评论者评论代码并插入成功。这是够我折腾的,多谢博主啦。

    • avatar
      Jager 2015-4-5 · 15:23

      是的,有点主题没有自定义这个回调函数,折腾才有进步。

  14. 运维网 2015-5-20 · 16:31

    那么问题来了,如何显示前面是图标然后跟着文字信息

  15. 第二度 2015-5-30 · 20:08

    用了几天,发现安卓手机用UC浏览器和自带浏览器评论都显示为:Safari浏览器。然后电脑用360浏览器评论,显示的是谷歌浏览器。这个是咋回事……

  16. 拽立网 2015-10-15 · 13:06

    继续学习!

  17. 新人求教 2015-10-25 · 21:31

    按你上面的方法,那个显示国家显示浏览器的都不能显示,而另外的那个本地显示IP的方法就行,只要你面调用,显示我的评论那里是是空白,头像在,而我用另一种方法能显示UA,只是没图片出来,调用放的位置是正确的,望博主更新一下心得,好吗?

  18. LEEJON 2016-2-14 · 15:23

    我的国旗显示比浏览器图标显示偏低小一点,这个怎么处理呀?

  19. 诸葛博客 2016-6-15 · 8:42

    签到成功!签到时间:下午6:19:17 ,每日签到,生活更精彩哦~请问我安装后怎么 IP 地址信息不显示呢? 能帮我看看嘛

  20. 无穷大 2016-7-20 · 10:36

    为什么显示在局域网呢

  21. 拾叁 2016-8-18 · 22:17

    试一下效果

  22. 拾叁 2016-8-18 · 22:17

    试一下啊效果!

  23. 转运女王 2016-11-30 · 9:30

    我太笨了,找不到怎么放代码呢 :???:

  24. 我爱武汉 2017-3-31 · 23:52

    callback=hui_comment_list 但是找不到hui_comment_list 函数 怎么办

  25. 堆爱博客 2017-4-11 · 15:58

    博主你好!插件有没有新版本啊!能不能放个新的下载链接呢?

  26. 飯特稀 2017-9-2 · 16:44

    QQ浏览器现在好像也检测不出来了!

  27. 飯特稀 2017-9-2 · 16:45

    试试QQ浏览器怎么样

  28. 米扑 2017-10-21 · 14:41

    测试下评论效果

  29. 绿茶 2018-7-19 · 15:23

    您好,有个问题想请教一下不知道方便不,我现在遇到一个问题,我想实现根据特定的一到两个User Agent返回不同的主题,应该如何实现呢。我在网上找的解决方案都集成了太多的UA了,都不太适合我目前现在的情况,比如找了个Mobile_Detect的PHP类库,但是里面包含的UA太多了,我只想针对那么一两个UA返回不同的主题。
    然后我又找了串代码,感觉这串应该比较适合,但是应该怎么修改一下呢。

    
    
    • avatar
      Jager 2018-8-4 · 16:52

      UA判断很好做啊,就是返回主题这个不知道怎么弄了。。

  30. 马也随笔 2019-1-7 · 11:28

    有时间研究一下

  31. 耗子 2020-3-28 · 21:31

    最新IP库下载的链接失效了,博主不打算补上?

  32. loukky 2021-3-27 · 1:14

    你好,博主。更新ip库以后只能显示ipv4的小国旗,然后我找到了个在线的api,可以同时支持ipv4与ipv6的查询,支持多种格式,这样就可以显示ipv6用户的小国旗了。请博主有空的时候添加一下这个在线查询的api,谢谢。API地址:http://ip2c.info/api.html
    烦请回复。。。