詳解WordPress中的頭像緩存和代理中的緩存更新方法
wordpress評論中的頭像是使用Gravatar的頭像服務(wù)(Gravatar官方注冊地址:http://en.gravatar.com),用戶的緩存頭像一般都是固定不變的,所以我們可以將頭像緩存到本地來提高我們網(wǎng)站的訪問速度。
我的wordpress avatar目錄的頭像緩存:

wordpress頭像緩存功能設(shè)置方法
首先是在根目錄下建立一個文件夾avatar,權(quán)限755。再在里面放一個默認(rèn)的頭像(default.jpg),沒頭像的童鞋就會用默認(rèn)的。代碼如下:
function my_avatar( $email, $size = '32', $default = '', $alt = '') {
$f = md5( strtolower( $email ) );
$a = WP_CONTENT_URL . '/avatar/'. $f . $size . '.png';
$e = WP_CONTENT_DIR . '/avatar/' . $f . $size . '.png';
$d = WP_CONTENT_DIR . '/avatar/' . $f . '-d.png';
if($default=='')
$default = 'http://www.wpnoob.cn/avatar/default.jpg'; //尺寸需要改為你自己網(wǎng)站評論的默認(rèn)頭像
$t = 2592000; // 緩存有效期30天, 這里單位:秒
if ( !is_file($e) || (time() - filemtime($e)) > $t ) {
if ( !is_file($d) || (time() - filemtime($d)) > $t ) {
// 驗證是否有頭像
$uri = 'http://www.gravatar.com/avatar/' . $f . '?d=404';
$headers = @get_headers($uri);
if (!preg_match("|200|", $headers[0])) {
// 沒有頭像,則新建一個空白文件作為標(biāo)記
$handle = fopen($d, 'w');
fclose($handle);
$a = $default;
}
else {
// 有頭像且不存在則更新
$r = get_option('avatar_rating');
$g = 'http://www.gravatar.com/avatar/'. $f. '?s='. $size. '&r=' . $r;
copy($g, $e);
}
}
else {
$a = $default;
}
}
$avatar = "<img alt='{$alt}' src='{$a}' class='avatar avatar-{$size} photo' height='{$size}' width='{$size}' />";
return apply_filters('my_avatar', $avatar, $email, $size, $default, $alt);
}
再將以上代碼添加到你主題的functions.php文件。
將獲取頭像地址的 get_avatar 函數(shù)替換為 my_avatar 。有個例外,functions.php評論列表函數(shù)中:
get_avatar( $comment
需要改成:
my_avatar( $comment->comment_author_email
因為my_avatar函數(shù)只能通過Email來調(diào)取用戶頭像,所以以上情況,需要將第一個參數(shù)改成email地址。
get_avatar函數(shù)介紹:
用上面的方法簡單方便啊。 不過還有一步是要注意的。得要確認(rèn)在調(diào)用頭像的地方都是用get_avatar函數(shù)來完成的。一般都是了,只有以前老的theme才不是。不是的話改過來就行。
如改為:
<?php
echo get_avatar( $comment->comment_author_email, $size = '48', $default = get_bloginfo('wpurl') . '/avatar/default.jpg' );
?>
代理(squid)中更新css/js文件緩存的方法
在wordpress添加css或者js文件,我們一般使用這四個函數(shù)來實現(xiàn):
- wp_enqueue_script()
- wp_enqueue_style()
- wp_register_script()
- wp_register_style()
函數(shù)中你可以定義css/js的版本號,以便我們在對css/js文件更新時能夠清楚瀏覽器的緩存,默認(rèn)的版本號是wordpress的版本號。版本號會鏈接在css/js完整路徑的后面,一般在版本號變更后,css/js載入的樣式的完整URL也會變更,瀏覽器發(fā)現(xiàn)URL變更會重新請求css/js文件,這樣就能達(dá)到載入最新的css/js文件。
但是很多代理軟件(比如squid)并不支持”?“號形式的cache,我們在使用反向代理來cache我們的網(wǎng)站時,特別在squid3.0以后,已經(jīng)開始不對帶”?”號的url進行緩存了。所以我們?nèi)绻褂胹quid的緩存功能就必須去掉”?”,更新squid代理商的緩存只能通過修改文件名來實現(xiàn)。
以下我們將介紹在wordpress通過對版本號的控制來修改js/css文件名從而能夠在代理軟件中達(dá)到緩存的目的:
1、在我們的主題代碼functions.php文件中添加如下代碼:
/**
* Description: wordpress在代理(squid)中更新css/js文件緩存的方法
* Author:wordpress教程網(wǎng)
* Author URI: http://www.wpnoob.cn/
*/
function ds_filename_based_cache_busting( $src ) {
// 管理員的后臺css/js文件無需處理
if ( is_admin() )
return $src;
//將版本號添加到文件名中已”.“號來區(qū)分
return preg_replace(
'/\.(js|css)\?ver=(.+)$/',
'.$2.$1',
$src
);
}
add_filter( 'script_loader_src', 'ds_filename_based_cache_busting' );
add_filter( 'style_loader_src', 'ds_filename_based_cache_busting' );
如果你使用的是apache服務(wù)器,在你的根目錄的.htaccess文件下添加:
<IfModule mod_rewrite.c>
RewriteEngine On
RewriteBase /
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
RewriteRule ^(.+)\.(.+)\.(js|css)$ $1.$3 [L]
</IfModule>
如果你是nginx服務(wù)器配置如下:
location ~ ^(.+)\.(.+)\.(js|css)$ {
alias $1.$3;
}
相關(guān)文章
php使用curl判斷網(wǎng)頁404(不存在)的方法
這篇文章主要介紹了php使用curl判斷網(wǎng)頁404(不存在)的方法,通過curl獲取http頭信息進行404錯誤判斷,非常簡便易懂,需要的朋友可以參考下2016-06-06
同臺服務(wù)器使用緩存APC效率高于Memcached的演示代碼
之前看到有文章說同臺服務(wù)器上APC的效率是Memcached的7倍,APC效率比Memcached高是肯定的,至于倒底快多少,我寫了個小程序測試了下。2010-02-02

