Jacky's Blog Jacky's Blog
  • 首页
  • 关于
  • 项目
  • 大事记
  • 留言板
  • 友情链接
  • 分类
    • 干货
    • 随笔
    • 项目
    • 公告
    • 纪念
    • 尝鲜
    • 算法
    • 深度学习
首页 › 干货 › WordPress 缓存 Gravatar 头像到服务器

WordPress 缓存 Gravatar 头像到服务器

Jacky
11月 11, 2016干货阅读 3,367

前言

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

WordPress 加速 加速网站
赞(0)
PHP 输出所有错误信息
上一篇
macOS 终端使用代理
下一篇
再想想
暂无评论
近期评论
  • Jacky发表在《Nginx UI》
  • daiwenzh5发表在《Nginx UI》
  • Jacky发表在《Nginx UI》
  • daiwenzh5发表在《Nginx UI》
  • Jacky发表在《Nginx UI》
  • 0
  • 0
Copyright © 2016-2023 Jacky's Blog. Designed by nicetheme.
粤ICP备16016168号-1
  • 首页
  • 关于
  • 项目
  • 大事记
  • 留言板
  • 友情链接
  • 分类
    • 干货
    • 随笔
    • 项目
    • 公告
    • 纪念
    • 尝鲜
    • 算法
    • 深度学习
# Mac # # Apple # # OS X # # iOS # # macOS #
Jacky
PHP C C++ Python | 舞象之年 | 物联网工程
174
文章
169
评论
267
喜欢