- 本篇文章实现了为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> 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> 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> MicroSoft Edge';
} else if (preg_match('#360([a-zA-Z0-9.]+)#i', $agent, $regs)) {
$outputer = '<i class="ua-icon icon-360"></i> 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> 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> 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> 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> UC浏览器';
} else if (preg_match('/Opera[\s|\/]([^\s]+)/i', $agent, $regs)) {
$outputer = '<i class= "ua-icon icon-opera"></i> 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> 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> Safari';
} else{
$outputer = '<i class="ua-icon icon-chrome"></i> Google Chrome';
}
echo $outputer;
}
// 获取操作系统信息
function getOs($agent)
{
$os = false;
if (preg_match('/win/i', $agent)) {
if (preg_match('/nt 6.0/i', $agent)) {
$os = ' <i class= "ua-icon icon-win1"></i> Windows Vista / ';
} else if (preg_match('/nt 6.1/i', $agent)) {
$os = ' <i class= "ua-icon icon-win1"></i> Windows 7 / ';
} else if (preg_match('/nt 6.2/i', $agent)) {
$os = ' <i class="ua-icon icon-win2"></i> Windows 8 / ';
} else if(preg_match('/nt 6.3/i', $agent)) {
$os = ' <i class= "ua-icon icon-win2"></i> Windows 8.1 / ';
} else if(preg_match('/nt 5.1/i', $agent)) {
$os = ' <i class="ua-icon icon-win1"></i> Windows XP / ';
} else if (preg_match('/nt 10.0/i', $agent)) {
$os = ' <i class="ua-icon icon-win2"></i> Windows 10 / ';
} else{
$os = ' <i class="ua-icon icon-win2"></i> Windows X64 / ';
}
} else if (preg_match('/android/i', $agent)) {
if (preg_match('/android 9/i', $agent)) {
$os = ' <i class="ua-icon icon-android"></i> Android Pie / ';
}
else if (preg_match('/android 8/i', $agent)) {
$os = ' <i class="ua-icon icon-android"></i> Android Oreo / ';
}
else{
$os = ' <i class="ua-icon icon-android"></i> Android / ';
}
}
else if (preg_match('/ubuntu/i', $agent)) {
$os = ' <i class="ua-icon icon-ubuntu"></i> Ubuntu / ';
} else if (preg_match('/linux/i', $agent)) {
$os = ' <i class= "ua-icon icon-linux"></i> Linux / ';
} else if (preg_match('/iPhone/i', $agent)) {
$os = ' <i class="ua-icon icon-apple"></i> iPhone / ';
} else if (preg_match('/mac/i', $agent)) {
$os = ' <i class="ua-icon icon-mac"></i> MacOS / ';
}else if (preg_match('/fusion/i', $agent)) {
$os = ' <i class="ua-icon icon-android"></i> Android / ';
} else {
$os = ' <i class="ua-icon icon-linux"></i> Linux / ';
}
echo $os;
}
最后
在handsome/component/comments.php
中找到合适位置添加以下代码:
(Mirages在mirages/libs/comments.php)
<span class="comment-ua">
<?php getOs($comments->agent); ?>
<?php getBrowser($comments->agent); ?></span>
闭路电视可以结合消防和安防系统,为经营者、警察局提供专业数据解决问题,减少时间成本,提升办事效率。
修改完后刷新浏览器缓存,现在你的评论UA已经变得很漂亮啦! ::quyin:1huaji::
这套图标很不错,简约画笔风,有dowload link?
你好,有的,我马上打包发给你 ::quyin:1huaji::
https://www.zrahh.com/library/icon.zip
感谢博主先生! ::quyin:laughing::
不客气OωO,话说,能不能把我从小黑屋拉出来先 ::quyin:angry::
好!不过我好像没查到你被拦截了,|´・ω・)ノ你是被报告判成机器人么??
原来你的网站被禁用了,奇怪,我没做这种操作哦!现在已经恢复,不好意思啊。。。
现在好啦!nice ::quyin:OK::
没事没事(๑•̀ㅁ•́ฅ)
::quyin:1huaji:: 图标很好看 ,拿走了
拿好|´・ω・)ノ
ヾ(´・ ・`。)ノ" 这个回复没有收到邮件通知呢
那个,,可能在垃圾箱 ::quyin:die::
你看看现在能收到不OωO
|´・ω・)ノ这个收到了 。也检查了垃圾箱 并没有
哈哈,这是我的错误 ::aru:cryingface:: ,刚才在个站商店 看到你了哎 ::aru:insidious::
::aru:meditation:: 我也发现了
(ノ°ο°)ノ 安装步骤弄好了 , 图标不显示啊,是不是css问题
你再看看,或者刷新下缓存,我这里看着你那里是显示的OωO
→_→对的,好了
::aru:shy:: 恳请大佬批本喵准转走这篇文章~
转吧OωO,注明出处就好~
Akina主题怎么弄
::quyin:amazing::
诶。。。打的字居然消失了,是Safari下的bug吗。。。
你打的啥呀,我还奇怪怎么没有内容呢∠( ᐛ 」∠)_
哈哈哈 当时打的“アイコンが綺麗ですね~”
嘿嘿,“ありがとう~” ::aru:flower::
图标挺好看的
嘿嘿,找了很久的 ::aru:shy::
学习了
互相学习 ::quyin:OK::
大赞,可以考虑整合到handsome
ヾ(≧∇≦*)ゝ
哈哈谢谢,有人用我开心了OωO
このPHPプラグインは独立して存在することができますか? ::twemoji:shy::
こんにちは、この小さな機能開発のためのプラグインはありません。 ::quyin:1huaji::
what?这是什么对话?
哈哈,应该是个日本人,他问我有没有为此功能开发独立的插件,我说没有 ::aru:unhappy::