实现EM评论头像缓存功能

大家都知道,博客的评论头像通常都是调用的 gravatar 网站的头像,有时候 gravatar 抽风,就会严重影响到页面的打开速度。于是大家纷纷使用缓存技术,将评论头像缓存到自己的空间上。虽然在正常情况下,这并不会加快页面的打开速度,但是在 gravatar 抽风的情况下,效果还是很明显的。之前写了个不用插件实现正常头像的文章,几天在为大家介绍一个方法。

实现缓存的方法调用,系统本身不是有一个 getGravatar 函数吗?如果能够让这个函数实现缓存功能,那就连模板都不用修改了,岂不是要简单得多?于是,我把实现缓存关键的那段代码加到了getGravatar 函数,又经过本地的反复试验,终于彻底实现了评论头像的缓存功能。下面,我就把我的方法讲一下。

首先,要在自己的空间上建立缓存目录。由于这个方法不依赖于模板,最好是建在网站根目录或者博客的安装目录下面,比如我的是:images\avatar(再次提醒:是根目录下面,不是模板目录下面)。建好目录之后,设置其权限为可写(777)。

然后就是修改 getGravatar 函数。打开 include\lib\function.base.php 文件,将原来的 getGravatar 函数重新命名作为备份,然后将下面的代码添加进去:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
//获取Gravatar头像   
function getGravatar($email, $s=64, $d='mm', $r='g') {   
    $f = md5($email);   
    $a = BLOG_URL.'images/avatar/'.$f.'.jpg';   
    $e = EMLOG_ROOT.'/images/avatar/'.$f.'.jpg';   
    $t = 1296000; //15天,单位:秒   
    if (empty($d)) $d = BLOG_URL.'images/avatar/default.jpg';   
    if (!is_file($e) || (time() - filemtime($e)) > $t ) {   
        //当头像不存在或者超过15天才更新   
        $g = sprintf("http://%d.gravatar.com",(hexdec($f{0})%2)).'/avatar/'.$f.'?s=64&d='.$d.'&r='.$r;   
        copy($g,$e); $a=$g; //新头像copy时, 取gravatar显示   
    }   
    if (filesize($e) < 500) copy($d,$e);   
    return $a;   
}

当中的路径一定要和你自己建的相同,保存之后重新上传覆盖,这样就行了。凡是原来正常调用 getGravatar 函数的地方(比如正文后面的评论、读者墙等),都会自动生效。

要注意的是,函数中的尺寸是控制复制过来的图片的大小,而不是该图片的显示尺寸;另外,如果当前页面的评论头像没有缓存完,页面可能显示不完全,网络不好甚至可能出现错误代码,不要着急,刷新一下,直到全部头像缓存完毕就正常了。

 

对于没有设置头像的邮箱,默认显示的头像如下:

 

$d=’mm’    – 神秘人  (灰色头像)

$d=’monsterid’ – 小怪物  (自动生成)

$d=’identicon’ - 抽象图形 (自动生成)

$d=’wavatar’  – W-avatar (自动生成)

$d=’非空格符’ – Gravatar (大写 “G”)

 

注意:$d 数据中的四个关键字只能是小写,不然会被视为其它的非空格符;另外,$d 的数据中也不能出现空格符,否则该函数将不能正常调用。

大家可以用鼠标右键查看一下本博客中评论头像的地址,是不是全部都在本空间里面?怎么样,如果觉得效果不错,就赶快动手吧!

未经允许不得转载:自由草 » 实现EM评论头像缓存功能

赞 (0)