代码
代码缓存方案来自 Willin Kan 大师,内容摘自 WP 大学,以下是具体做法:
①、建立缓存目录
在 wp-content 的同級目录建立一个文件夹,命名为 avatar ,设置该文件夹的权限为 0755 (如果 0755 不行,就试一下 0777)。
②、设置默认头像
准备一张大小适合的默认头像,命名为”default.jpg” ,放在 avatar 文件夹里面。
③、添加缓存代码
将下面的代码复制到模板的 functions.php 文件中即可:
function my_avatar($avatar) {
$tmp = strpos($avatar, 'http');
$g = substr($avatar, $tmp, strpos($avatar, "'", $tmp) - $tmp);
$tmp = strpos($g, 'avatar/') + 7;
$f = substr($g, $tmp, strpos($g, "?", $tmp) - $tmp);
$w = get_bloginfo('wpurl');
$e = ABSPATH .'avatar/'. $f .'.jpg';
$t = 1209600; //設定14天, 單位:秒
if ( !is_file($e) || (time() - filemtime($e)) > $t ) { //當頭像不存在或文件超過14天才更新
copy(htmlspecialchars_decode($g), $e);
} else $avatar = strtr($avatar, array($g => $w.'/avatar/'.$f.'.jpg'));
if (filesize($e) < 500) copy($w.'/avatar/default.jpg', $e);
return $avatar;
}
add_filter('get_avatar', 'my_avatar');
插件
知更鸟博主分享了一个 gavatar 头像缓存到本地的插件:nix-gravatar-cache
启用后到设置→头像缓存→勾选“启用Gravatar头像缓存”保存设置。
第一次启用插件,打开网页会很慢,因为插件正在缓存头像,过一会恢复正常。
修改缓存来源并做了简单的汉化,插件兼容七牛云存储
2018年07月21日兼容最新版本WP。
感谢您的来访,获取更多精彩文章请收藏本站。

© 版权声明
THE END
暂无评论内容