首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >解决WordPress头像优化Gravatar加载延迟高本地化保存加速

解决WordPress头像优化Gravatar加载延迟高本地化保存加速

作者头像
AlexTao
修改2023-05-16 13:16:31
1.8K0
修改2023-05-16 13:16:31
举报
文章被收录于专栏:钻芒博客钻芒博客

说到网站速度优化,一直以来都有一个小小的问题,那就是Gravatar头像,这个东西加载时快时慢,某一时候加载不正常延迟非常高,十分拖累网站加载速度,而网上很多之前的加速接口好像也都已失效。今天来让这个东西加载后自动保存在本地,下次加载直接使用本地链接。放在自己这里稳定高效。

一,创建缓存目录

在你的WordPress根目录创建一个avatar 的文件夹,权限调整为755

二,设置默认头像

并不是所有人都设置了Gravatar头像,我们给那些没有头像的设置一个默认图片,没有头像就显示这个图片。

avatar文件夹放入一张名称为default.jpg的图片,默认没有头像即使用这个图片。

#:这里钻芒这里并默认没有调用这张图片,而是依然使用Gravatar头像。可能是之前魔改导致的,这一步仅供参考

三,将下边的代码放到 functions.php

把下边的代码放到你主题的functions.php内,默认14天刷新一下本地头像缓存,可根据自己自定义。

//Gravatar 头像本地化加速
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');

最终实现效果查看

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一,创建缓存目录
  • 二,设置默认头像
  • 三,将下边的代码放到 functions.php
  • 最终实现效果查看
相关产品与服务
网站建设
网站建设(Website Design Service,WDS),是帮助您快速搭建企业网站的服务。通过自助模板建站工具及专业设计服务,无需了解代码技术,即可自由拖拽模块,可视化完成网站管理。全功能管理后台操作方便,一次更新,数据多端同步,省时省心。使用网站建设服务,您无需维持技术和设计师团队,即可快速实现网站上线,达到企业数字化转型的目的。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档