wordpress博客默認用的就是Gravatar頭像了,但現在它已經在強外了,所以我們為了提升它的訪問性能可以嘗試使用緩存功能來解決這個問題,具體的操作步驟如下。
現在越來越多的網站支持Gravatar頭像,越來越多的網友設置了個性化Gravatar頭像,wordpress也是默認使用Gravatar頭像,但是Gravatar畢竟是在墻外的,當一個頁面上需要展示很多個Gravatar頭像的時候,難免會影響到頁面載入速度,為了提高用戶體驗,我們可以把頭像文件緩存到本地服務器上。
首先在你的博客根目錄下創建一個文件夾,專門用來存放緩存的Gravatar頭像文件,比如“avatar”,權限設置同目錄下其他文件。然后在修改functions.php文件,或者主題自帶functions文件的話,可以在主題的functions文件上修改,末尾處添加以下代碼,自行設置頭像超時天數。然后刷新下頁面看看頭像能否正常顯示,再去后臺看看avatar目錄下是否創建了緩存文件。
- <?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 = 2592000; //?定30天, ?撾?秒
- if ( !is_file($e) || (time() - filemtime($e)) > $t ) { //??像不存在或文件超?30天才更新
- 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; //Vevb.com
- }
- add_filter('get_avatar', 'my_avatar');
- ?>
除了此方法外還可以使用插件來實現,現在整理了幾款插件,頭像緩存插件:
GravatarLocalCache
FV Gravatar Cache
WP Gravatar Mini Cache
Gravatar Cache
Hacklog Gravatar Cache
以上頭像緩存插件,功能類似,都是把Gravatar頭像下載到本地服務器上,然后讀取緩存的圖片,從而提高加載速度。啟用插件后,第一次打開有頭像的頁面可能會較慢,因為正在下載緩存圖片,之后速度會明顯提升。
新聞熱點
疑難解答
圖片精選