WordPress为没有Gravatar头像的用户加载随机头像
发布时间:2025-10-19 15:52:50 本站作者 【 字体:大 中 小 】 浏览:78 次
教程介绍
当你想到判断用户是否有gravatar头像时,大多能找到网上搜到一些老办法,就是通过get_headers 远程取得gravatar服务器响应一个 HTTP 请求所发送的所有标头。看看是否是404,再回头判断是否该加载自定义头像。
思路
而我们通常不会采用上述方式,就是因为这个 get_headers 的过程非常耗时。今天JV给大家提供两个更快的思路。
都是不通过get_headers直接使用前端和wp已有的默认手段来达到为没有gravatar头像的用户加载随机头像的目的。
根据gravatar网站关于头像请求中d参的介绍,我们可以拿其中的404和Default Image两种形式来进行前端输出。
在主题的 functions.php 中加入以下代码
/**
* 为没有Gravatar头像的用户加载随机头像
* @author INLOJV
* @URI http://www.inlojv.com/20170521randomgravatar.html
*
*/add_filter( 'get_avatar' , 'inlojv_custom_avatar' , 10 , 5 );function inlojv_custom_avatar( $avatar, $id_or_emAIl, $size, $default, $alt) {
global $comment,$current_user;
// $id_or_email的值:后台右上角登录用户头像为id,其他为邮箱,下面做一个判断
$current_email = is_int($id_or_email) ? get_user_by( 'ID', $id_or_email )->user_email : $id_or_email;
$email = !empty($comment->comment_author_email) ? $comment->comment_author_email : $current_email ;
$random_avatar_arr = array(
'//wx1.sinaimg.cn/square/6b002b97gy1ffs6ulm8ojj20690690sl.jpg',
'//wx1.sinaimg.cn/square/6b002b97gy1ffs6ulfp76j2069069t8p.jpg',
'//wx1.sinaimg.cn/square/6b002b97gy1ffs6ukuo5dj2069069a9w.jpg',
'//wx1.sinaimg.cn/square/6b002b97gy1ffs6ujijfoj206z05l746.jpg',
'//wx1.sinaimg.cn/square/6b002b97gy1ffs6uimd6zj207705edfr.jpg'
);
$email_hash = md5(strtolower(trim($email)));
$random_avatar = array_rand($random_avatar_arr,1);
$src = $random_avatar_arr[$random_avatar] ;
// JV提示:d参数404 onerror 方法 - 速度最快
$avatar = "<img alt='{$alt}' src='//secure.gravatar.com/avatar/{$email_hash}?d=404' onerror='JavaScript:this.src="{$src}";this.onerror=null;' class='avatar avatar-{$size} photo' height='{$size}' width='{$size}' />";
// JV提示:d参数default_img 方法 - 速度稍逊
// $src = urlencode( $src );
//$avatar = "<img alt='{$alt}' src='//secure.gravatar.com/avatar/{$email_hash}?d={$src}' class='avatar avatar-{$size} photo' height='{$size}' width='{$size}' />";
return $avatar;}如代码中所注释的那样,第一种方法是直接采用img标签的onerror属性,当图片链接返回404时直接输出我们自定义的随机图片;第二种方法是利用d参数返回默认链接从而加载随机图片。
另外,我把随机图片写成了数组,这样你就可以使用外链图片链接作为随机头像的链接,若你需要添加新的图片,可以依样画葫芦每行添加一条图片外链即可。 以上!
Gravatar官方参考资料:http://cn.gravatar.com/site/implement/images/
Office2019激活密钥,office2019专业版产品激活码,2026.5最新分享
Office2021密钥激活码,Office2021专业版产品激活密钥最新2026
office2010 产品密钥,office2010永久激活密钥最新分享包括图文教程
office 2021正式版激活密钥,office2021专业正式版产品激活码免费分享
Office2019激活密钥,office2019专业版产品激活码,2026.5最新分享

Office2021密钥激活码,Office2021专业版产品激活密钥最新2026

office2010 产品密钥,office2010永久激活密钥最新分享包括图文教程

office 2021正式版激活密钥,office2021专业正式版产品激活码免费分享

正版 office2019产品密钥,office2019专业版激活密钥 office2019 永久激活

Office2020专业版永久激活秘钥,office2020产品激活码(图文教程)

office2020产品激活密钥激活方法,office2020 永久激活码【转】

2026最新office2010激活密钥分享,office2010永久激活码产品激活密钥(附激活教程)

2026年5月更新,office2020 永久激活的激活密钥,office2020 产品激活密钥激活码(附激活教程)

Office2010产品密钥激活密钥,2026最新的Office2010产品密钥激活码有哪些?

