【转载】wordpress评论头像的显示问题

我们用wordpress做网站的时候,在评论这块势必会用到Gravatar头像的,但是,这个Gravatar头像是国外的产品,打开/显示速度这块并不是很快,根据不同的网络差异化也很大。。。那么今天的教程,就是教大家如何将Gravatar头像本地化,让头像存在我们自己的空间内,那这个速度就会提升很多!好了,直接进入教程吧!

本地缓存法

在wordpress主题文件的functions.php内加入一下代码:(仅适合国外的主机,国内还是访问不了)

//本地加载GV头像

  1. function my_avatar($avatar) {  
  2.     $tmp = strpos($avatar, 'http');  
  3.     $g = substr($avatar$tmpstrpos($avatar"'"$tmp) - $tmp);  
  4.     $tmp = strpos($g, 'avatar/') + 7;  
  5.     $f = substr($g$tmpstrpos($g"?"$tmp) - $tmp);  
  6.     $w = get_bloginfo('wpurl');  
  7.     $e = ABSPATH .'avatar/'. $f .'.jpg';  
  8.     $t = 604800; //設定7天, 單位:秒  
  9.     if ( !is_file($e) || (time() - filemtime($e)) > $t ) {  
  10.         copy(htmlspecialchars_decode($g), $e);  
  11.     } else  $avatar = strtr($avatararray($g => $w.'/avatar/'.$f.'.jpg'));  
  12.     if (filesize($e) < 500) copy($w.'/avatar/default.jpg', $e);  
  13.     return $avatar;  
  14. }  
  15. add_filter('get_avatar','my_avatar');  

然后,在网站根目录新建名为“avatar”的文件夹,设置文件夹权限为777。并放一个JPG格式的图片(名为default)作为默认头像。这样,刷新你们的网站,再看看,头像的地址是不是本地化了?

七牛、多说缓存法

如果大家有安装七牛插件的话,那么直接使用下面的代码放入functions.php即可缓存本地化

  1. function replace_avatar_url($avatar) {  
  2.     $avatar = str_replace(array("www.gravatar.com","0.gravatar.com","1.gravatar.com","2.gravatar.com"),"ds-gravatar.qiniudn.com",$avatar);  
  3.     return $avatar;  
  4. }  
  5. add_filter( 'get_avatar', 'replace_avatar_url', 10, 3 );  

https直接访问法

如果没有安装七牛插件,那么https还是没被墙的,而且速度还不错,直接调用这个最简单了。
如果你的网站启用了ssl则不需要了,否则functions.php 加入如下代码

  1. function get_ssl_avatar($avatar) {  
  2.    $avatar = preg_replace('/.*/avatar/(.*)?s=([d]+)&.*/','<img src="https://secure.gravatar.com/avatar/$1?s=$2" class="avatar avatar-$2" height="$2" width="$2">',$avatar);  
  3.    return $avatar;  
  4. }  
  5. add_filter('get_avatar', 'get_ssl_avatar');  

好了,大家不用谢我,大叔是雷锋,更是wordpress的搬运工!

原文地址

本文作者: chenishr

本文标题:《【转载】wordpress评论头像的显示问题》

本文地址: http://blog.chenishr.com/?p=306

©版权所有,除非注明, 永在路上文章均为原创,转载请以链接形式注明出处和作者细信息。

发表评论

电子邮件地址不会被公开。 必填项已用*标注