當前位置:首頁 > CMS教程 > WordPress > 列表

詳解WordPress中的頭像緩存和代理中的緩存更新方法

發布:smiling 來源: PHP粉絲網  添加日期:2019-11-29 10:58:06 瀏覽: 評論:0 

wordpress評論中的頭像是使用Gravatar的頭像服務(Gravatar官方注冊地址:http://en.gravatar.com),用戶的緩存頭像一般都是固定不變的,所以我們可以將頭像緩存到本地來提高我們網站的訪問速度。

wordpress頭像緩存功能設置方法

首先是在根目錄下建立一個文件夾avatar,權限755。再在里面放一個默認的頭像(default.jpg),沒頭像的童鞋就會用默認的,代碼如下:

  1. function my_avatar( $email$size = '32'$default = ''$alt = '') { 
  2.  
  3.  $f = md5( strtolower$email ) ); 
  4.  
  5.  $a = WP_CONTENT_URL . '/avatar/'$f . $size . '.png'
  6.  
  7.  $e = WP_CONTENT_DIR . '/avatar/' . $f . $size . '.png'
  8.  
  9.  $d = WP_CONTENT_DIR . '/avatar/' . $f . '-d.png'
  10.  
  11. //phpfensi.com 
  12.  
  13.  if($default==''
  14.  
  15.   $default = 'http://www.euncrd.live/avatar/default.jpg'; //尺寸需要改為你自己網站評論的默認頭像 
  16.  
  17.  $t = 2592000; // 緩存有效期30天, 這里單位:秒 
  18.  
  19.  if ( !is_file($e) || (time() - filemtime($e)) > $t ) { 
  20.  
  21.   if ( !is_file($d) || (time() - filemtime($d)) > $t ) { 
  22.  
  23.    // 驗證是否有頭像 
  24.  
  25.    $uri = 'http://www.gravatar.com/avatar/' . $f . '?d=404'
  26.  
  27.    $headers = @get_headers($uri); 
  28.  
  29.    if (!preg_match("|200|"$headers[0])) { 
  30.  
  31.     // 沒有頭像,則新建一個空白文件作為標記 
  32.  
  33.     $handle = fopen($d'w'); 
  34.  
  35.     fclose($handle); 
  36.  
  37.  
  38.  
  39.     $a = $default
  40.  
  41.    } 
  42.  
  43.    else { 
  44.  
  45.     // 有頭像且不存在則更新 
  46.  
  47.     $r = get_option('avatar_rating'); 
  48.  
  49.     $g = 'http://www.gravatar.com/avatar/'$f'?s='$size'&r=' . $r
  50.  
  51.     copy($g$e); 
  52.  
  53.    } 
  54.  
  55.   } 
  56.  
  57.   else { 
  58.  
  59.    $a = $default
  60.  
  61.   } 
  62.  
  63.  } 
  64.  
  65.  $avatar = "<img alt="{$alt}" src="{$a}" class="avatar avatar-{$size} photo" height="{$size}" width="{$size}">"
  66.  
  67.  return apply_filters('my_avatar'$avatar$email$size$default$alt); 
  68.  

再將以上代碼添加到你主題的functions.php文件。

將獲取頭像地址的 get_avatar 函數替換為 my_avatar 。有個例外,functions.php評論列表函數中:

get_avatar( $comment

需要改成:

my_avatar( $comment->comment_author_email

因為my_avatar函數只能通過Email來調取用戶頭像,所以以上情況,需要將第一個參數改成email地址。

get_avatar函數介紹:

用上面的方法簡單方便啊。 不過還有一步是要注意的。得要確認在調用頭像的地方都是用get_avatar函數來完成的。一般都是了,只有以前老的theme才不是。不是的話改過來就行。

如改為:

  1. <?php 
  2.  
  3.  echo get_avatar( $comment->comment_author_email, $size = '48'$default = get_bloginfo('wpurl') . '/avatar/default.jpg' );  
  4.  
  5. ?> 

代理(squid)中更新css/js文件緩存的方法

在wordpress添加css或者js文件,我們一般使用這四個函數來實現:

wp_enqueue_script()

wp_enqueue_style()

wp_register_script()

wp_register_style()

函數中你可以定義css/js的版本號,以便我們在對css/js文件更新時能夠清楚瀏覽器的緩存,默認的版本號是wordpress的版本號。版本號會鏈接在css/js完整路徑的后面,一般在版本號變更后,css/js載入的樣式的完整URL也會變更,瀏覽器發現URL變更會重新請求css/js文件,這樣就能達到載入最新的css/js文件。

但是很多代理軟件(比如squid)并不支持”?“號形式的cache,我們在使用反向代理來cache我們的網站時,特別在squid3.0以后,已經開始不對帶”?”號的url進行緩存了。所以我們如果要使用squid的緩存功能就必須去掉”?”,更新squid代理商的緩存只能通過修改文件名來實現。

以下我們將介紹在wordpress通過對版本號的控制來修改js/css文件名從而能夠在代理軟件中達到緩存的目的:

1、在我們的主題代碼functions.php文件中添加如下代碼:

  1. /**  
  2.  
  3.  * Description: wordpress在代理(squid)中更新css/js文件緩存的方法 
  4.  
  5.  * Author:wordpress教程網 
  6.  
  7.  * Author URI: http://www.euncrd.live/ 
  8.  
  9.  */ 
  10.  
  11. function ds_filename_based_cache_busting( $src ) { 
  12.  
  13.  // 管理員的后臺css/js文件無需處理 
  14.  
  15.  if ( is_admin() ) 
  16.  
  17.  return $src
  18.  
  19.  //將版本號添加到文件名中已”.“號來區分 
  20.  
  21.  return preg_replace( 
  22.  
  23.  '/\.(js|css)\?ver=(.+)$/'
  24.  
  25.  '.$2.$1'
  26.  
  27.  $src 
  28. //phpfensi.com 
  29.  ); 
  30.  
  31.  
  32. add_filter( 'script_loader_src''ds_filename_based_cache_busting' ); 
  33.  
  34. add_filter( 'style_loader_src''ds_filename_based_cache_busting' ); 

如果你使用的是apache服務器,在你的根目錄的.htaccess文件下添加:

  1. <ifmodule mod_rewrite.c=""> 
  2.  
  3.    RewriteEngine On 
  4.  
  5.    RewriteBase / 
  6.  
  7.    RewriteCond %{REQUEST_FILENAME} !-f 
  8.  
  9.    RewriteCond %{REQUEST_FILENAME} !-d 
  10.  
  11.    RewriteRule ^(.+)\.(.+)\.(js|css)$ $1.$3 [L] 
  12.  
  13. </ifmodule> 

如果你是nginx服務器配置如下:

  1. location ~ ^(.+)\.(.+)\.(js|css)$ { 
  2.  
  3.   alias $1.$3
  4.  
  5. }? 

Tags: WordPress頭像緩存

分享到:

六合图库图纸印刷网