喵喵博客志 记录喵喵美好生活
歌曲封面 未知作品
  • 歌曲封面ひこうき雲松任谷由実
  • 歌曲封面El Pueblo Unido Jamás Será Vencido (En Vivo)Quilapayun
  • 歌曲封面I wish来栖りん
  • 歌曲封面冬の花宮本浩次
  • 歌曲封面So Cute~Lopu$

萌ICP备20210005号

辽ICP备2021005644号

辽公网安备 21021102000984号

绯色之喵 @2009

十年之约计划 4 年 71 天 14 小时 10 分

Powered by Typecho & Sunny

3 online · 195 ms

Title

对于JOE主题,使用自定义头像,解决部分评论没有头像的问题

绯色之喵

·

Article
⚠️ 本文最后更新于2022年09月23日,已经过了604天没有更新,若内容或图片失效,请留言反馈
方案一

博客使用经常会遇到有的评论没有头像,直接返回显示Gavatar默认的头像,不仅难看的要死,还没办法更改,严重影响美观(比如我这半个强迫症+半个完美主义者),而且joe主题默认判断使用的是qq头像,使用了qq邮箱的Gavatar头像就不会显示了,因此为了解决这个问题,我折腾了好久才解决(主要是不会qaq

步骤1

对于joe7.x主题

  1. 定位到主题目录下文件\Joe\core\function.php,查找
  2. 将内容替换成以下:

    ♾️ php 代码:
    /* 通过邮箱生成头像地址(火喵改) */
    function _getAvatarByMail($mail)
    {
     $gravatarsUrl = Helper::options()->JCustomAvatarSource ? Helper::options()->JCustomAvatarSource : 'https://gravatar.cooluc.com/avatar/';
     $mailLower = strtolower($mail);
     $md5MailLower = md5($mailLower);
     $qqMail = str_replace('@qq.com', '', $mailLower);
     
     $uri = 'https://cdn.helingqi.com/wavatar/' . $md5MailLower . '?d=404';
     $headers = @get_headers($uri);
     
     if (preg_match("|200|", $headers[0])) {
         echo $gravatarsUrl . $md5MailLower . '?d=mm';
     } 
     elseif (strstr($mailLower, "qq.com") && is_numeric($qqMail) && strlen($qqMail) < 11 && strlen($qqMail) > 4) {
         echo 'https://thirdqq.qlogo.cn/g?b=qq&nk=' . $qqMail . '&s=100';
     }
     else {
         echo '自定义头像地址';
     }
    }

    建议将之前的内容注释掉,不要删除。

步骤2
  1. 定位到主题目录下文件\Joe\core\core.php,查找
  2. 将内容替换成以下:
♾️ php 代码:
/* 通过邮箱生成头像地址(火喵改) */
function _getAvatarUrlByMail($mail)
{
    $gravatarsUrl = Helper::options()->JCustomAvatarSource ? Helper::options()->JCustomAvatarSource : 'https://gravatar.cooluc.com/avatar/';
    $mailLower = strtolower($mail);
    $md5MailLower = md5($mailLower);
    $qqMail = str_replace('@qq.com', '', $mailLower);
    
    $uri = $gravatarsUrl . $md5MailLower . '?d=404';
    $headers = @get_headers($uri);
    
    if (preg_match("|200|", $headers[0])) {
        return $gravatarsUrl . $md5MailLower . '?d=mm';
    } 
    elseif (strstr($mailLower, "qq.com") && is_numeric($qqMail) && strlen($qqMail) < 11 && strlen($qqMail) > 4) {
        return 'https://thirdqq.qlogo.cn/g?b=qq&nk=' . $qqMail . '&s=100';
    } else {
        return '自定义头像地址https://cat.dorcandy.cn/000pages/api/api-mc.php';
    }
}

保存好刷新查看效果。

其他

有的主题版本在core.php中无法找到关键词,找不到就直接跳过,无需修改文件即可。

简单的原理就是,依据邮箱去查找是否存在头像,如果不存在会返回状态码404,依据状态码的不同来判断。但是我这样设置完,网站加载变得异常迟钝,不知道原因所在,希望有大佬赐教,感谢。

  1. 图片地址可以使用api地址,譬如火喵博客的MC酱API。
  2. 可以尝试使用随机函数,比如
♾️ html 代码:
'images/'.rand(1,5).'.jpg'
方案二

方案一虽然完美,但是使用此方法会被发送大量的请求,如果页面的头像数据多,会导致网站相应及其缓慢,我都受不了了,于是想到了一个新的方案——使用onerror事件

对于joe7.x主题

  1. 定位到主题目录下文件\Joe\core\function.php,查找
  2. 将内容echo $gravatarsUrl . $md5MailLower . '?d=mm';替换成echo $gravatarsUrl . $md5MailLower . '?d=404';(没错就是把mm改成404)
  3. 主题设置——全局设置——自定义JS中,填入:
♾️ javascript 代码:
/* 头像替换 */
function imgerrorfun(){ 
    var img=event.srcElement; 
    img.src="替换的头像地址"; 
    img.onerror=null;
}

然后在主题文件——Joe/public/comment.php中,查找

♾️ php 代码:
<img width="48" height="48"----------

将其改为

♾️ php 代码:
<img onerror="imgerrorfun();" width="48" height="48"----------

没错就是中间加了个onerror="imgerrorfun();"
同理在主题文件——Joe/public/aside.php中,查找

♾️ php 代码:
<img width="40" height="40" class="avatar lazyload" src="<?php _getAvatarLazyload(); ?>" data-src="<?php _getAvatarByMail($item->mail) ?>" alt="<?php $item->author(false) ?>" />

同样将其改为

♾️ php 代码:
<img onerror="imgerrorfun();" width="40" height="40"----------

如遇到没显示的地方,如法炮制即可。

方案三

通过查看Gavatar文档,我们发现官方有一个可用的方案:
2021-11-5-13-56-22.png

因此,我们可以将最后的代码部分修改成诸如此类的便可:

♾️ php 代码:
else {
        echo $gravatarsUrl . $md5MailLower . '?d=https%3A%2F%2Fcat.dorcandy.cn%2logo';
    }
方案四(仅参考)

推荐使用方案二,方案三仅仅是一个思路,就是将img标签改为div,并使用background-image来叠加两张图片来显示效果。因为404的图片在background-image下会不显示,直接显示下一张图。但是遇到了有的邮箱是透明png,这样的话显示就重叠了,无法达到效果,因此舍弃。

方案五(11月5日追加)

现在推荐使用 Cravatar - 互联网公共头像服务 ,一步到位。

现在已有 0 条评论,0 人点赞
Comment
发表
搜 索 消 息 足 迹
你还不曾留言过..
你还不曾留下足迹..
博主