大家都知道,博客的评论头像通常都是调用的 gravatar 网站的头像,有时候 gravatar 抽风,就会严重影响到页面的打开速度。于是大家纷纷使用缓存技术,将评论头像缓存到自己的空间上。虽然在正常情况下,这并不会加快页面的打开速度,但是在 gravatar 抽风的情况下,效果还是很明显的。 WP 早就实现了评论头像的缓存,EM 也有不少技术控已经实现了。8 {& W6 x# j, {% {2 g
这三种方法我在本地都调试成功,用过之后感觉其实都差不多。于是就在三者之中选了一个相对而言比较简单一点的,就是小松的缓存代码,加在了我的模板之中。 但是,我自己还使用了小松的读者墙插件,插件本身是没有缓存功能的。为了让读者墙插件也实现缓存功能,还得修改插件,这对于我这种编程白痴来说,实在是太困难了。不过通过在本地的无数次试验,最后还是成功了,不过只成功了一半——日志页面的读者墙能够实现,但是侧边栏的读者墙死活实现不了——最后只好把侧边栏的读者墙关掉。没办法,谁让咱不会编程呢? 就这样罢手实在是心有不甘啊!后来我就想,实现缓存的方法实质上就是自己创建一个新的函数,然后加以调用嘛!系统本身不是有一个 getGravatar 函数吗?如果能够让这个函数实现缓存功能,那就连模板都不用修改了,岂不是要简单得多?于是,我把实现缓存关键的那段代码加到了getGravatar 函数,又经过本地的反复试验,终于彻底实现了评论头像的缓存功能。下面,我就把我的方法讲一下。 首先,要在自己的空间上建立缓存目录。由于这个方法不依赖于模板,最好是建在网站根目录或者博客的安装目录下面,比如我的是:images\avatar (再次提醒:是根目录或者博客安装目录,不是模板目录)。建好目录之后,设置其权限为可写 (777)。 然后就是修改 getGravatar 函数。打开 include\lib\function.base.php 文件,将原来的 getGravatar 函数重新命名作为备份,然后将下面的代码添加进去: //获取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' - 神秘人 (灰色头像)8 U1 k/ L h7 x( k' Q
$d='monsterid' - 小怪物 (自动生成)
! d0 H% F- m7 H $d='identicon' - 抽象图形 (自动生成)
2 _% {2 z" ?) `+ }* U! {& h $d='wavatar' - W-avatar (自动生成)
, P4 z8 O: x( b $d='非空格符' - Gravatar (大写 “G”) 注意:$d 数据中的四个关键字只能是小写,不然会被视为其它的非空格符;另外,$d 的数据中也不能出现空格符,否则该函数将不能正常调用。 大家可以用鼠标右键查看一下本博客中评论头像的地址,是不是全部都在本空间里面?怎么样,如果觉得效果不错,就赶快动手吧!
6 X! P3 E" q( Y6 X3 m0 m% m, Y4 d |