当前所在位置: 首页>>百科全书

WordPress为没有Gravatar头像的用户加载随机头像

发布时间:2025-10-19 15:52:50 本站作者 【 字体: 】 浏览:35 次

教程介绍

当你想到判断用户是否有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/


上一篇:解决comment_class或body_class输出暴露注册用户名的问题

下一篇:Office 2007怎么美化表格?Office 2007怎么套用表格格式

广告位-300PX*250PX
最新发布
盐水花生的制作方法(让你在家也能享受美味的盐水花生)

盐水花生的制作方法(让你在家也能享受美味的盐水花生)

盐水花生的制作方法(让你在家也能享受美味的盐水花生)
盐水花生是一种非常受欢迎的小吃,不仅在路边摊上可以买到,而且在家也能轻松制作。下面将为大家介绍盐水花生的制作方法。准备食材——花生、盐、水在开始做盐水花生之前,我们需要准备好所需的食材。这些食材包括花生、盐和水。花生要用新鲜的,最好不要用已经发霉或变质的。清洗花生清洗花生是制作盐水花生的重要步骤。将...
芝士章鱼小丸子,手把手教你做(传承日式美食,美味满满的小丸子,营养又健康)

芝士章鱼小丸子,手把手教你做(传承日式美食,美味满满的小丸子,营养又健康)

芝士章鱼小丸子,手把手教你做(传承日式美食,美味满满的小丸子,营养又健康)
日式美食一直以来深受大家的喜爱,而其中的小丸子更是备受推崇。除了其独特的口感外,小丸子的制作方法也因其简单易学而广受欢迎。本文将以芝士章鱼小丸子为主题,为大家详细介绍其做法。准备原材料在制作芝士章鱼小丸子前,我们需要准备好以下原材料:章鱼片、鲜虾、芝士、寿司米、水、味噌汤、葱花、柠檬片等。将寿司米用...
教你做香酥烤鸡腿(美食制作的艺术,轻松做出口感香脆的鸡腿)

教你做香酥烤鸡腿(美食制作的艺术,轻松做出口感香脆的鸡腿)

教你做香酥烤鸡腿(美食制作的艺术,轻松做出口感香脆的鸡腿)
鸡腿是很多人喜欢的食物之一,不仅营养丰富,口感也非常好。而香酥烤鸡腿更是让人回味无穷。今天,我要和大家分享一下如何做出香酥可口的烤鸡腿,让你在家就能享受到美味的享受。一:选购优质食材为了做出美味的烤鸡腿,首先要选购优质的食材。新鲜的鸡腿肉质细嫩,没有异味,而且能保证肉质的弹性和口感。此外,在选择调料...
手工番薯泥的做法(用心制作,健康美味)

手工番薯泥的做法(用心制作,健康美味)

手工番薯泥的做法(用心制作,健康美味)
健康饮食已成为当今人们追求的生活方式,而自己动手制作美味健康的食品更是一种享受。番薯泥作为一道经典美食,在日常生活中备受青睐。下面我们就来分享一下自制番薯泥的做法,让大家可以在家轻松制作出美味健康的番薯泥。1.选购新鲜番薯选购时以颜色均匀,表皮光滑无伤痕为宜,大小适中的番薯为佳。2.去皮切块将番薯去皮后...