WordPress 缓存不同大小的 Gravatar 头像

关于 wordpress 缓存 Gravatar 头像到本地,提升网站加载速度的文章已经到处都是,但是之前的一些 wordpress 头像缓存解决方案都是只能缓存一个大小的头像,而这里就将一个升级版给大家分享一下,这也是在做 Fanly 主题中用到的一个功能,毕竟在 wordpress 博客中,很多时候我们不仅仅只是使用一种头像大小,如果网站调用了多个尺寸的头像可能调用大头像的时候会不清晰。

改善功能:支持不同大小的头像;支持自动创建缓存目录。

下面就不多说了,把一下代码加入到你主题的 functions.php 中即可:

//缓存 Gravatar 头像
add_filter('get_avatar', 'fanly_cache_avatar');
function fanly_cache_avatar($avatar) {
	if(!is_dir('avatar'))//判断是否有缓存目录
		mkdir('avatar', 0755, true);//否者创建头像缓存目录
	$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 = home_url();
	list($width,$height,$type,$attr) = getimagesize($g);//获取头像参数
	$e = ABSPATH .'avatar/'. $f .'-'.$width.'.jpg';
	$t = 604800; //设定 7 天, 单位:秒
	if ( empty($default) ) $default = 'https://i.leiue.com/avatar.php';
	if ( !is_file($e) || (time() - filemtime($e)) > $t ){ //当头像不存在或者文件超过 7 天才更新
		copy(htmlspecialchars_decode($g), $e);
	}else{
		$avatar = strtr($avatar, array($g => $w.'/avatar/'.$f.'-'.$width.'.jpg'));
	}
	if (filesize($e) < 500) copy($default, $e);
	return $avatar;
}

在开发的时候,你还可以再这段代码收尾加上一个控制功能,方便开启或者关闭头像缓存功能。

当然在新版的 wordpress 中,get_avatar 函数已经支持 srcset 来适应高清屏,一些不好的代码在高清屏下可能出现问题。开发者们还是按照自己的喜好或许需要来进行合适的开发和适配咯!

好啦!就给大家分享到这里了,欢迎大家支持原创 wordpress 主题:Fanly

本文链接:https://www.abcziyuan.com/templateplug-in/wordpress-course/4909.html

开通VIP会员
分享到: 生成海报
免责声明1. 本站所有资源来源于用户上传和网络,均不允许转载,如有侵权请邮件联系站长!
2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 如发现会员转载本站资源文章,本站有权封禁会员账号!
4. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
5. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
6. 如有链接无法下载、失效或广告,请联系管理员处理!
7. 本站资源售价只是赞助,收取费用仅维持本站的日常运营所需!
8. 如遇到加密压缩包,默认解压密码为"www.abcziyuan.com",如遇到无法解压的请联系管理员!
开通VIP会员
切换注册

登录

忘记密码 ?

切换登录

注册

我们将发送一封验证邮件至你的邮箱, 请正确填写以完成账号注册和激活