詳解WordPress中的頭像緩存和代理中的緩存更新方法
wordpress評論中的頭像是使用Gravatar的頭像服務(wù)(Gravatar官方注冊地址:http://en.gravatar.com),用戶的緩存頭像一般都是固定不變的,所以我們可以將頭像緩存到本地來提高我們網(wǎng)站的訪問速度。
我的wordpress avatar目錄的頭像緩存:
wordpress頭像緩存功能設(shè)置方法
首先是在根目錄下建立一個(gè)文件夾avatar,權(quán)限755。再在里面放一個(gè)默認(rèn)的頭像(default.jpg),沒頭像的童鞋就會(huì)用默認(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 ) { // 驗(yàn)證是否有頭像 $uri = 'http://www.gravatar.com/avatar/' . $f . '?d=404'; $headers = @get_headers($uri); if (!preg_match("|200|", $headers[0])) { // 沒有頭像,則新建一個(gè)空白文件作為標(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 。有個(gè)例外,functions.php評論列表函數(shù)中:
get_avatar( $comment
需要改成:
my_avatar( $comment->comment_author_email
因?yàn)閙y_avatar函數(shù)只能通過Email來調(diào)取用戶頭像,所以以上情況,需要將第一個(gè)參數(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文件,我們一般使用這四個(gè)函數(shù)來實(shí)現(xiàn):
- wp_enqueue_script()
- wp_enqueue_style()
- wp_register_script()
- wp_register_style()
函數(shù)中你可以定義css/js的版本號(hào),以便我們在對css/js文件更新時(shí)能夠清楚瀏覽器的緩存,默認(rèn)的版本號(hào)是wordpress的版本號(hào)。版本號(hào)會(huì)鏈接在css/js完整路徑的后面,一般在版本號(hào)變更后,css/js載入的樣式的完整URL也會(huì)變更,瀏覽器發(fā)現(xiàn)URL變更會(huì)重新請求css/js文件,這樣就能達(dá)到載入最新的css/js文件。
但是很多代理軟件(比如squid)并不支持”?“號(hào)形式的cache,我們在使用反向代理來cache我們的網(wǎng)站時(shí),特別在squid3.0以后,已經(jīng)開始不對帶”?”號(hào)的url進(jìn)行緩存了。所以我們?nèi)绻褂胹quid的緩存功能就必須去掉”?”,更新squid代理商的緩存只能通過修改文件名來實(shí)現(xiàn)。
以下我們將介紹在wordpress通過對版本號(hào)的控制來修改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 ) { // 管理員的后臺(tái)css/js文件無需處理 if ( is_admin() ) return $src; //將版本號(hào)添加到文件名中已”.“號(hào)來區(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錯(cuò)誤判斷,非常簡便易懂,需要的朋友可以參考下2016-06-06簡單實(shí)現(xiàn)限定phpmyadmin訪問ip的方法
如果你需要限定phpmyadmin特定的ip地址段進(jìn)行訪問,一個(gè)簡單的方式可以在配置文件中進(jìn)行簡單限定。2013-03-03同臺(tái)服務(wù)器使用緩存APC效率高于Memcached的演示代碼
之前看到有文章說同臺(tái)服務(wù)器上APC的效率是Memcached的7倍,APC效率比Memcached高是肯定的,至于倒底快多少,我寫了個(gè)小程序測試了下。2010-02-02