Skip to content

  • Home
  • Archives
  • Tools
  • Links
  • Guest
  • About

Let's whisper

  • 程序开发
    • PHP
    • Python
    • HTML/CSS
    • JavaScript
    • 服务器
    • 数据库
    • 微信开发
    • 区块链
    • 作品展示
  • 应用程序
    • 开发工具
    • 操作系统
    • 桌面应用
    • 移动应用
    • 网页应用
  • WordPress
  • 探索发现
    • 音乐
    • 影视
    • 图像
    • 资讯
    • 设计创意
    • 新技能
  • 个人日志

Home WordPress 全面启用gravatar头像缓存

全面启用gravatar头像缓存

2009/09/14 39,705
    把Gravatar头像缓存到本地服务器,避免访客每次都从gravatar.com下载头像,有效提升了博客访问速度。因为我用的是国内空间,所以启用头像缓存有一个更重要的意义:让用教育网的同学也可以看到头像。Let's whisper有两个地方用到了gravatar头像:评论列表和最新评论(启用了wp-recentcomments插件),所以这两处都要进行缓存。
我用的启用gravatar头像缓存的方法来自willin,取名为“小g”,也许这是世界上最小巧的gravatar头像缓存方案。下面我就介绍一下这个方法,特别是iNove用户,往下看咯。
1、对评论列表里的gravatar头像启用缓存
先在你的网站 wp-content 的同级目录 建立文件夹: /avatar 权限:755, 这是准备 gravatar 缓存的路径。
找到原来的 comments.php 或是在 functions.php 里的 function mytheme_comment($comment, $args, $depth) 会有一段像这样:

<?php echo get_avatar($comment,$size='50',$default='<path_to_url>' ); ?>

如果你用的iNove主题,在functions.php里会有下面的一段:

<?php if (function_exists('get_avatar') && get_option('show_avatars')) { echo get_avatar($comment, 32); } ?>

把这个换成:

<?php
$p = 'avatar/';
$f = md5(strtolower($comment->comment_author_email));
$a = $p . $f .'.jpg';
$e = ABSPATH . $a;
if (!is_file($e)){    //当头像不存在就更新
$d = get_bloginfo('url'). '/avatar/default.jpg';
$s = '50';
$r = get_option('avatar_rating');
$g = 'http://www.gravatar.com/avatar/'.$f.'.jpg?s='.$s.'&d='.$d.'&r='.$r;
copy($g, $e);
if ( filesize($e) == 0 ){ copy($d, $e); }
};
?>
<img src='<?php echo $a ?>' alt='' />

预设头像 default.jpg, 放在刚刚建立的 avatar 文件夹内,当访客不是gravatar用户时就会调用这个头像。 上面的变量名顺便解释一下: $p 是 path(路径), $f 是 filename(档案名), $a 是 avatar(缓存档案), $e 是服务器路径, $d 是 default(预设头像), $s 是 size(尺寸), $r 是 rate(分级), $g 是 gravatar(原始档案)。
如果想要更新头像,去ftp里把 /avatar 路径下的头像文件删除就可以了。
2、对wp-recentcomments插件的头像启用缓存
在 /wp-recentcomments 路径下找到 core.php,其中有这么一段:

function rc_get_avatar($show, $position, $size, $default, $email) { 
$avatar = '';
if ($show == 'true' && function_exists('get_avatar') && get_option('show_avatars')) {
// 当默认头像来自 Internet 时
if (substr(strtolower($default), 0, 7) == 'http://') {
$file = attribute_escape($default);
$avatar = '<div class="rc_avatar rc_' . $position . '">' . get_avatar($email, $size, $file) . '</div>';
// 当默认头像来自 "/wp-recentcomments/avatars/" 目录时
} else if ($default != '') {
$file = 'wp-content/plugins/wp-recentcomments/avatars/' . $default;
if (file_exists($file)) {
$file = get_bloginfo('siteurl') . '/' . $file;
$avatar = '<div class="rc_avatar rc_' . $position . '">' . get_avatar($email, $size, $file) . '</div>';
}
// 当不包含默认头像时
} else {
$avatar = '<div class="rc_avatar rc_' . $position . '">' . get_avatar($email, $size) . '</div>';
}
}
return $avatar;
}

改成:

function rc_get_avatar($show, $position, $size, $default, $email) { 
$avatar = '';
if ($show == 'true' && function_exists('get_avatar') && get_option('show_avatars')) {
$p = 'avatar/';
$f = md5(strtolower($email));
$a = $p . $f .'.jpg';
$e = ABSPATH . $a;
if (!is_file($e)){
if ($default){$d = $default;} else {$d = get_bloginfo('url'). '/avatar/default.jpg';}
$r = get_option('avatar_rating');
$g = 'http://www.gravatar.com/avatar/'.$f.'.jpg?s='.$size.'&d='.$d.'&r='.$r;
copy($g, $e);
if ( filesize($e) == 0 ){ copy($d, $e); }
};
$avatar = '<div class="rc_avatar rc_' . $position . '"><img src="'.$a.'" style="width:'.$size.'px;height:'.$size.'px;" alt="" /></div>';
}
return $avatar;
}

完成。
重要提示:  如果采用这个方法后,文章页面无法显示头像,而且头像地址变成形如www.whisperer.name/cache-gravatar/avatar/...的样子,请把上面代码中的$p = 'avatar/'改成$p = '/avatar/'

Posted in WordPress   Tagged gravatar, WordPress, 博客历程

恰克

本页链接: https://miu.im/?p=52

最近更新: 2014/12/15

62条评论

  1. Gravatar头像缓存的几种方法 | 一瞬视觉工作室
    10年 ago Permalink
  2. lampre jerseys
    9年前 回复

    来看看

←Previous 1 2 3 4

发表评论 取消回复

😉😐😡😈😣😯😦😤😛😳😮😢😆💡😀👿😥😎😃😕😄😁😂😨😧😅

Previous Post: 令人惊叹的动物眼睛[10P]
Next Post: 启用新的空间

Primary Sidebar

相关文章

  • 博客启用了七牛 CDN
  • 调用「ONE · 一个」每日一句作为站点描述
  • 启用了 WordPress 缓存插件
  • 启用新的favicon图标
  • 为文章生成二维码

近期文章

  • 您好,2021
  • max_input_vars
  • 提升效率的几个 VSCode 快捷键
  • TA-Lib Installation
  • iPhone 使用的几个小技巧
  • 再次回归
  • Visual Studio Code disable auto wrap long line
  • KeePass 复制条目到另一个数据库
  • Chrome DevTools 小技巧两则
  • 区块链投资
Loading

功能

  • 登录
  • 条目feed
  • 评论feed
  • WordPress.org

Copyright © 2009-2021 Let's whisper. Powered by WordPress and Stargazer.