柚子素材 - www.yozsc.com上线啦!!!

MENU

Typecho博客评论显示UserAgent(UA)

March 7, 2019 • Read: 7295 • 网站优化阅读设置

  • 本篇文章实现了为Typecho博客文章评论添加显示UserAgent(UA)的功能
  • 本功能可替代UserAgent插件,更美观、简洁且好看

一. 简介

由于想给博客加一个文章评论显示UserAgent功能,在网上搜寻并尝试了UserAgent插件,但是并不如意。一是因为他太过臃肿,虽然几乎可以识别市面上所有的OS和浏览器,但是我们常用的也就几个而已,大多数都用不到,二是图标太老旧了,而且清晰度很低,在博客上显得突兀且不美观。


于是我结合网上的代码,以及网上开源的图标的png格式重新安排了一个Comment-UA,支持主流操作系统以及浏览器(图标没找到匹配的就没整,不认识的浏览器通通视为Google Chrome ::quyin:1huaji:: ),目前图片全部放在又拍云存储,不用担心拖慢速度。

图标均来自开源图标icons8.cn以及 MBE Style图标包

二. 效果显示

  • 大概就是这样了,实际效果请看我的评论!
  • 目前可以识别的操作系统以及浏览器

食用方法

这里以handsome为例,其他主题操作方法类似(VOID配置看评论)。

首先

将下面这段css全部加入到 handsome/assets/css/handsome.min.css 末尾。
点击查看

也可后台加入自定义css或是直接在header.php中引入

然后

找到handsome/functions.php,将下面代码完整复制,加到functions.php文件的最末尾

// 获取浏览器信息
function getBrowser($agent)
{
    if (preg_match('/MSIE\s([^\s|;]+)/i', $agent, $regs)) {
        $outputer = '<i class="ua-icon icon-ie"></i>&nbsp;&nbsp;Internet Explore';
    } else if (preg_match('/FireFox\/([^\s]+)/i', $agent, $regs)) {
      $str1 = explode('Firefox/', $regs[0]);
$FireFox_vern = explode('.', $str1[1]);
        $outputer = '<i class="ua-icon icon-firefox"></i>&nbsp;&nbsp;FireFox';
    } else if (preg_match('/Maxthon([\d]*)\/([^\s]+)/i', $agent, $regs)) {
      $str1 = explode('Maxthon/', $agent);
$Maxthon_vern = explode('.', $str1[1]);
        $outputer = '<i class="ua-icon icon-edge"></i>&nbsp;&nbsp;MicroSoft Edge';
    } else if (preg_match('#360([a-zA-Z0-9.]+)#i', $agent, $regs)) {
$outputer = '<i class="ua-icon icon-360"></i>&nbsp;&nbsp;360极速浏览器';
    } else if (preg_match('/Edge([\d]*)\/([^\s]+)/i', $agent, $regs)) {
        $str1 = explode('Edge/', $regs[0]);
$Edge_vern = explode('.', $str1[1]);
        $outputer = '<i class="ua-icon icon-edge"></i>&nbsp;&nbsp;MicroSoft Edge';
    } else if (preg_match('/UC/i', $agent)) {
              $str1 = explode('rowser/',  $agent);
$UCBrowser_vern = explode('.', $str1[1]);
        $outputer = '<i class="ua-icon icon-uc"></i>&nbsp;&nbsp;UC浏览器';
    }  else if (preg_match('/QQ/i', $agent, $regs)||preg_match('/QQBrowser\/([^\s]+)/i', $agent, $regs)) {
                  $str1 = explode('rowser/',  $agent);
$QQ_vern = explode('.', $str1[1]);
        $outputer = '<i class= "ua-icon icon-qq"></i>&nbsp;&nbsp;QQ浏览器';
    } else if (preg_match('/UBrowser/i', $agent, $regs)) {
              $str1 = explode('rowser/',  $agent);
$UCBrowser_vern = explode('.', $str1[1]);
        $outputer = '<i class="ua-icon icon-uc"></i>&nbsp;&nbsp;UC浏览器';
    }  else if (preg_match('/Opera[\s|\/]([^\s]+)/i', $agent, $regs)) {
        $outputer = '<i class= "ua-icon icon-opera"></i>&nbsp;&nbsp;Opera';
    } else if (preg_match('/Chrome([\d]*)\/([^\s]+)/i', $agent, $regs)) {
$str1 = explode('Chrome/', $agent);
$chrome_vern = explode('.', $str1[1]);
        $outputer = '<i class="ua-icon icon-chrome""></i>&nbsp;&nbsp;Google Chrome';
    } else if (preg_match('/safari\/([^\s]+)/i', $agent, $regs)) {
         $str1 = explode('Version/',  $agent);
$safari_vern = explode('.', $str1[1]);
        $outputer = '<i class="ua-icon icon-safari"></i>&nbsp;&nbsp;Safari';
    } else{
        $outputer = '<i class="ua-icon icon-chrome"></i>&nbsp;&nbsp;Google Chrome';
    }
    echo $outputer;
}
// 获取操作系统信息
function getOs($agent)
{
    $os = false;
 
    if (preg_match('/win/i', $agent)) {
        if (preg_match('/nt 6.0/i', $agent)) {
            $os = '&nbsp;&nbsp;<i class= "ua-icon icon-win1"></i>&nbsp;&nbsp;Windows Vista&nbsp;/&nbsp;';
        } else if (preg_match('/nt 6.1/i', $agent)) {
            $os = '&nbsp;&nbsp;<i class= "ua-icon icon-win1"></i>&nbsp;&nbsp;Windows 7&nbsp;/&nbsp;';
        } else if (preg_match('/nt 6.2/i', $agent)) {
            $os = '&nbsp;&nbsp;<i class="ua-icon icon-win2"></i>&nbsp;&nbsp;Windows 8&nbsp;/&nbsp;';
        } else if(preg_match('/nt 6.3/i', $agent)) {
            $os = '&nbsp;&nbsp;<i class= "ua-icon icon-win2"></i>&nbsp;&nbsp;Windows 8.1&nbsp;/&nbsp;';
        } else if(preg_match('/nt 5.1/i', $agent)) {
            $os = '&nbsp;&nbsp;<i class="ua-icon icon-win1"></i>&nbsp;&nbsp;Windows XP&nbsp;/&nbsp;';
        } else if (preg_match('/nt 10.0/i', $agent)) {
            $os = '&nbsp;&nbsp;<i class="ua-icon icon-win2"></i>&nbsp;&nbsp;Windows 10&nbsp;/&nbsp;';
        } else{
            $os = '&nbsp;&nbsp;<i class="ua-icon icon-win2"></i>&nbsp;&nbsp;Windows X64&nbsp;/&nbsp;';
        }
    } else if (preg_match('/android/i', $agent)) {
    if (preg_match('/android 9/i', $agent)) {
            $os = '&nbsp;&nbsp;<i class="ua-icon icon-android"></i>&nbsp;&nbsp;Android Pie&nbsp;/&nbsp;';
        }
    else if (preg_match('/android 8/i', $agent)) {
            $os = '&nbsp;&nbsp;<i class="ua-icon icon-android"></i>&nbsp;&nbsp;Android Oreo&nbsp;/&nbsp;';
        }
    else{
            $os = '&nbsp;&nbsp;<i class="ua-icon icon-android"></i>&nbsp;&nbsp;Android&nbsp;/&nbsp;';
    }
    }
    else if (preg_match('/ubuntu/i', $agent)) {
        $os = '&nbsp;&nbsp;<i class="ua-icon icon-ubuntu"></i>&nbsp;&nbsp;Ubuntu&nbsp;/&nbsp;';
    } else if (preg_match('/linux/i', $agent)) {
        $os = '&nbsp;&nbsp;<i class= "ua-icon icon-linux"></i>&nbsp;&nbsp;Linux&nbsp;/&nbsp;';
    } else if (preg_match('/iPhone/i', $agent)) {
        $os = '&nbsp;&nbsp;<i class="ua-icon icon-apple"></i>&nbsp;&nbsp;iPhone&nbsp;/&nbsp;';
    } else if (preg_match('/mac/i', $agent)) {
        $os = '&nbsp;&nbsp;<i class="ua-icon icon-mac"></i>&nbsp;&nbsp;MacOS&nbsp;/&nbsp;';
    }else if (preg_match('/fusion/i', $agent)) {
        $os = '&nbsp;&nbsp;<i class="ua-icon icon-android"></i>&nbsp;&nbsp;Android&nbsp;/&nbsp;';
    } else {
        $os = '&nbsp;&nbsp;<i class="ua-icon icon-linux"></i>&nbsp;&nbsp;Linux&nbsp;/&nbsp;';
    }
    echo $os;
}

最后

handsome/component/comments.php中找到合适位置添加以下代码:

<span class="comment-ua">
    <?php getOs($comments->agent); ?>
    <?php getBrowser($comments->agent); ?></span>

如果修改完都显示Linux的话,需要将上面的$comments替换成$this即可,注意代码缩进

现在你的评论UA已经变得很漂亮啦! ::quyin:1huaji::

Leave a Comment

135 Comments
  1. 墨兰 墨兰     Android Oreo /    Google Chrome

    感谢博主!那我可拿走了哦::quyin:1huaji::

    1. 左岸 左岸     Windows 10 /    Google Chrome

      @墨兰拿好@(笑眼)

  2. LOGI LOGI     Windows 10 /    Google Chrome

    我在想,你的 cdn 挂了,我们都得遭殃@(滑稽)

    1. 左岸 左岸     Windows 10 /    Google Chrome

      @LOGI@(滑稽)七牛云挂了我的cdn也不会挂@(滑稽)

  3. lzy lzy     Windows 10 /    FireFox

    前来围观

    1. 左岸 左岸     MacOS /    Google Chrome

      @lzy欢迎~

  4. 崔先森 崔先森     Ubuntu /    Google Chrome

    今天看到评论里出现这种情况,这是乍回事?
    @(泪)https://img.cnelite.org/img-url/1905/c3689acc62b523c4.png

    1. 左岸 左岸     Android Pie /    Google Chrome

      @崔先森这个,你重新复制一下我function.php里的代码就好啦@(滑稽)

    2. 崔先森 崔先森     Ubuntu /    Google Chrome

      @左岸原来如此,修改过啊,我都没发觉.
      https://img.cnelite.org/img-url/1905/d8e652fdd5fc4e38.png
      @(真棒)

    3. 左岸 左岸     Android Pie /    Google Chrome

      @崔先森你是不是用的比较早了,我偷偷修改过一次@(你懂的)

  5. jerry jerry     Linux /    Google Chrome

    过来感谢以下大佬!@(哈哈)

    1. 左岸 左岸     Android Pie /    Google Chrome

      @jerry不客气哦(´-ω-`)

  6. 殊途 殊途     Windows 10 /    Google Chrome

    请问这个评论提交的按钮是直接改了css还是用了插件?

    1. 左岸 左岸     Android Pie /    Google Chrome

      @殊途我这是老版的mirages哦,你如果想换我这种样式的话直接改下css就可以@(滑稽)

    2. 殊途 殊途     iPhone /    Safari

      @左岸好的,我用的是新版,老版和新版有什么区别吗

    3. 左岸 左岸     MacOS /    Google Chrome

      @殊途当然是新版更好啦!新的版本在这里有详细介绍。
      我是懒得换而已#(狂汗)

  7. 枫叶 枫叶     Windows 10 /    Google Chrome

    教程不错,准备部署到自己博客上去的,分析了下,现在基本上都是win10和mac,浏览器也是大众的谷歌浏览器和火狐。还是多谢博客写出教程来,很不错。@(吐舌)

    1. 左岸 左岸     MacOS /    Google Chrome

      @枫叶对呀,基本常用的就这几个了2333@(滑稽)

  8. 墨鱼君 墨鱼君     Windows 10 /    Google Chrome

    自动获取评论者头像是怎么实现的呢?根据邮箱地址吗?我换个邮箱测试一下,如果有打扰可以删除哈。

    1. 墨鱼君 墨鱼君     Windows 10 /    Google Chrome

      @墨鱼君果然用QQ邮箱就有,换个网易的就没了,好神奇

    2. 左岸 左岸     MacOS /    Google Chrome

      @墨鱼君23333确实是根据邮箱,这个qq官方提供接口的,其他邮箱通过申请Gravatar头像也可以@(滑稽)

  9. 她与空白 她与空白     Android /    Google Chrome

    解决了@(勉强)

  10. 她与空白 她与空白     Android /    Google Chrome

    在handsome 5.1.1上报错Call to undefined function getBrowser()
    Error: Call to undefined function getBrowser() in /www/users/CH587040/WEB/usr/themes/handsome/component/comments.php:74
    Stack trace:

    0 /www/users/CH587040/WEB/var/Widget/Comments/Archive.php(80): threadedComments(Object(Widget_Comments_Archive), Object(Typecho_Config))1 /www/users/CH587040/WEB/var/Widget/Comments/Archive.php(423): Widget_Comments_Archive->threadedCommentsCallback()2 /www/users/CH587040/WEB/usr/themes/handsome/libs/Content.php(2370): Widget_Comments_Archive->listComments()3 /www/users/CH587040/WEB/usr/themes/handsome/component/comments.php(196): Content::returnCommentList(Object(Widget_Archive), Object(Widget_Comments_Archive))4 /www/users/CH587040/WEB/var/Widget/Archive.php(1937): require('/www/users/CH58...')5 /www/users/CH587040/WEB/usr/themes/handsome/post.php(83): Widget_Archive->need('component/comme...')6 /www/users/CH587040/WEB/var/Widget/Archive.php(2022): require_once('/www/users/CH58...')7 /www/users/CH587040/WEB/var/Typecho/Router.php(138): Widget_Archive->render()8 /www/users/CH587040/WEB/index.php(23): Typecho_Router::dispatch()9 {main}