前言
Gravatar 是 Globally Recognized Avatar 的缩写,是 Gravatar 推出的一项服务,意为“全球通用头像”。如果在Gravatar 中上传了自己的头像,那么在任何支持 Gravatar 的 Blog 或者留言本上留言时,只要提供你与这个头像关联的 e-mail 地址,就能够显示出你的 Gravatar 头像来。
然而,国内基本上已经不能愉快的访问了,即使没有被墙,头像下载的速度也是非常的缓慢,严重拖慢网站的加载速度。前段时间听朋友说应该自己缓存 Gravatar 头像,一开始我认为利用第三方的 CDN(多说、V2EX 等)就可以实现加速的效果了吧,但最近发现,这些第三方的 CDN 也有会抽风的时候,导致有一天网站卡到十几秒加载不完  ̄へ ̄,于是今天就来尝试下这个缓存的方法。
函数代码
1.请先在站点的根目录下新建目录 avatar
并确定其用户组和用户与站点目录相同,赋予权限 0755
。
2.上传一张 default.jpg 作为默认头像,另外在WP后台默认头像最好设置为空。
3.将下列代码放置到 functions.php 或在 functions.php 所引用的 php 文件当中
function cache_avatar($avatar, $id_or_email, $size, $default, $alt)
{
$avatar = str_replace(array("www.gravatar.com", "0.gravatar.com", "1.gravatar.com", "2.gravatar.com"), "cn.gravatar.com", $avatar);
$tmp = strpos($avatar, 'http');
$url = get_avatar_url( $id_or_email, $size ) ;
$url = str_replace(array("www.gravatar.com", "0.gravatar.com", "1.gravatar.com", "2.gravatar.com"), "cn.gravatar.com", $url);
$avatar2x = get_avatar_url( $id_or_email, ( $size * 2 ) ) ;
$avatar2x = str_replace(array("www.gravatar.com", "0.gravatar.com", "1.gravatar.com", "2.gravatar.com"), "cn.gravatar.com", $avatar2x);
$g = substr($avatar, $tmp, strpos($avatar, "'", $tmp) - $tmp);
$tmp = strpos($g, 'avatar/') + 7;
$f = substr($g, $tmp, strpos($g, "?", $tmp) - $tmp);
$w = home_url();
$e = ABSPATH .'avatar/'. $size . '*'. $f .'.jpg';
$e2x = ABSPATH .'avatar/'. ( $size * 2 ) . '*'. $f .'.jpg';
$t = 1209600;
if ( (!is_file($e) || (time() - filemtime($e)) > $t) && (!is_file($e2x) || (time() - filemtime($e2x)) > $t ) ) {
copy(htmlspecialchars_decode($g), $e);
copy(htmlspecialchars_decode($avatar2x), $e2x);
} else { $avatar = $w.'/avatar/'. $size . '*'.$f.'.jpg';
$avatar2x = $w.'/avatar/'. ( $size * 2) . '*'.$f.'.jpg';
if (filesize($e) < 1000) copy($w.'/avatar/default.jpg', $e);
if (filesize($e2x) < 1000) copy($w.'/avatar/default.jpg', $e2x);
$avatar = "<img alt='{$alt}' src='{$avatar}' srcset='{$avatar2x}' class='avatar avatar-{$size} photo' height='{$size}' width='{$size}' />";
}
return $avatar;
}
add_filter('get_avatar', 'cache_avatar',1,5);
后记
1. 首次打开页面的速度可能会较为缓慢因为在下载头像,缓存完毕后再打开站点速度会有明显提升,本站的加载速度已回归毫秒级别,O(∩_∩)O哈哈~
2. 如果添加了代码函数,站点出现无响应或加载速度极其缓慢,检查元素发现链接没有正常替换的话,请检查 avatar
目录是否有写权限。
3. 本文参考自 https://www.wpdaxue.com/gravatar-cache.html
评论 (0)