詳解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進(jìn)行緩存了。所以我們?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頭信息進(jìn)行404錯誤判斷,非常簡便易懂,需要的朋友可以參考下2016-06-06同臺服務(wù)器使用緩存APC效率高于Memcached的演示代碼
之前看到有文章說同臺服務(wù)器上APC的效率是Memcached的7倍,APC效率比Memcached高是肯定的,至于倒底快多少,我寫了個小程序測試了下。2010-02-02