天天看點

wordpress優化:Gravatar頭像被牆及解決方案Gravatar 頭像被牆及解決方案

當中的原因就是Gravatar頭像引起的,gravatar.com的伺服器在美國加利福尼亞州舊金山市,再加上諸多的原因,在我們網站上是很難緩存Gravatar頭像的,進而拖累了網站的打開速度。

每位留言者根據自己的郵箱會顯示不同的Gravatar頭像,如果一篇文章的留言者非常多,比如幾百個以上,就會顯示幾百個Gravatar頭像圖檔,圖檔越多,HTTP請求也就越多,容易導緻網頁加載緩慢、網站出現打不開的現象。

目前有不少的有名氣的部落格已經取消了顯示Gravatar頭像,目的就是為了最大限度地加快網頁的加載速度,畢竟在浏覽網頁内容和留言兩者之間,擷取網頁内容才是第一位的,評論隻是一種互動方式。

wordpress優化方法:主要有兩種,其一是将Gravatar頭像緩存到本地空間;其二是Gravatar頭像緩存到國内鏡像伺服器。

要想将Wordpress的Gravatar頭像圖檔緩存到本地,先在網站的根據目錄建立一個avatar 的檔案夾,讀寫權限設定為755。

有些留言者的郵箱可能沒有注冊Gravatar頭像,我們需要用到一個預設的圖檔替代這樣的留言者的頭像,将一張default.jpg 的圖檔作為預設頭像放在avatar檔案夾中。

打開你的主題的 functions.php 檔案,編輯内容。

将以下代碼複制粘貼到你的functions.php最後,預設的是14天更新一次頭像圖檔,你可以自己修改為更短時間。

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');

WordPress的Gravatar頭像圖檔緩存到本地後,圖檔的路徑不再是Gravatar官網的URL了,而是本地伺服器的圖檔位址了。

将Wordpress頭像緩存到多說Gravatar頭像國内鏡像伺服器。

2、方法的原理是:官方的Gravatar 頭像所在的路徑一般都是www.gravatar.com、0.gravatar.com、1.gravatar.com、2.gravatar.com 這四個,我們隻需要将頭像預設的URL換成多說的就行了。

3、打開主題下的functions.php 檔案,将以下代碼複制粘貼儲存即可。

function mytheme_get_avatar($avatar) {

    $avatar = str_replace(array("www.gravatar.com","0.gravatar.com","1.gravatar.com","2.gravatar.com"),

"gravatar.duoshuo.com",$avatar);

    return $avatar;

add_filter( 'get_avatar', 'mytheme_get_avatar', 10, 3 );

同理利用此方法,我們還可以在七牛中自己建立一個Gravatar官網頭像伺服器,然後将以下代碼複制到functions.php 檔案中,就可以讓Gravatar 頭像的外鍊位址變成七牛的CDN了。

"dadu2.qiniudn.com",$avatar);

今天在幾個朋友的幫助下發現Gravatar 應該是徹底被牆了,根本無法通路了,可能是最近大會或者什麼其他原因吧,還有人因為什麼被抓起來了,太多東西也不好評價。我Gril Friend Wall 果然是天下無敵。

年紀大了折騰的精力就不如從前了,隻想用最簡單的方法解決問題,我采用了第一種方法,直接調用官方的資料,理論上應該是最穩定的了(沒被牆的前提下)。

https還是沒被牆的,而且速度還不錯,直接調用這個最簡單了。

如果你的網站啟用了ssl則不需要了,否則<code>functions.php </code>加入如下代碼

優點:簡單穩定

缺點: 當頭像特别大時速度可能略慢

下面的代碼加到<code>functions.php</code>中

在WordPress安裝根目(即跟wp-content等檔案夾同一目錄下)下建立一個名為 avatar 的檔案夾 ,并給予寫權限。放入一張同尺寸的頭像圖檔命名為default.jpg。

優點:和主機速度挂鈎,如果你的伺服器特别快則頭像加載也特别快

缺點:隻能緩存一個尺寸的頭像,國内主機無法使用

via:willin

注:多說部分頭像會被回源,導緻無法顯示,是以也不推薦這個方案

優點:

缺點:我最煩多說了

還有七牛緩存之類的,網上有很多,大家可以随便搜搜,個人最推薦的是第一種方法

當然也可以把頭像關閉掉,即可禁用Gravatar頭像

如何聯系我:【萬裡虎】www.bravetiger.cn

【QQ】3396726884 (咨詢問題100元起,幫助解決問題500元起)

【部落格】http://www.cnblogs.com/kenshinobiy/

繼續閱讀