Cravatar 开放公测,彻底解决 Gravatar 无法访问的问题

什么是Gravatar

Gravatar是WordPress母公司Automattic推出的一个公共头像服务,也是WordPress默认的头像服务。但因为长城防火墙的存在,Gravatar在中国时不时就会被墙一下,比如本次从2021年2月一直到8月都是不可访问状态。

在以往的时候,国内的CDN厂商和博客主会使用反代的方式确保Gravatar在国内能正常访问,但老实说,这种方式很容易就会吃牢饭。不妨想一下,Gravatar为什么会墙?一定是出现了某些涉政、涉黄之类的违法内容。这些国家禁止的东西,我们将其反代入国内,可谓是细思极恐。同时反代也只能解决头像访问的问题,而解决不了头像上传的问题。

介绍Cravatar

好在,现在我们有了Cravatar。

Cravatar是WordPress本土化计划中生态基础设施的一部分,就和我们构建的翻译平台及应用市场一样。

Cravatar 100%兼容Gravatar的头像API,这意味着你可以简单的通过替换域名的方式来使用Cravatar接替Gravatar。同时,作为对中国互联网环境的特别适配,Cravatar支持在用户未设置Cravatar头像及Gravatar头像时匹配QQ头像(仅限于使用QQ数字邮箱的用户),这一切是自动进行的,用户对此无感知。其带来的效果是:经过三级匹配(Cravatar头像->Gravatar头像->QQ头像)后,大约70%的访客都会得到准确的头像。

此外,我们还会对所有头像进行人工审核,确保不会出现害群之马。

总的来说,Cravatar在100%兼容Gravatar的同时还有以下优势:

  1. 更快的速度 – 服务完全架设并运行在中国大陆境内,提供毫秒级的响应速度
  2. 更高的稳定性 – 所有头像经人工审核确保不会出现违规内容,也就不会出现时不时访问不了的情况
  3. 更高的头像展现率 – 在自有头像库的基础上囊括了Gravatar和QQ的头像库,可谓集天下之大成

如何使用

如果你想为你的WordPress接入Cravatar可以直接将以下代码加入你的主题或插件中(任何开发者都可以将该服务集成到自己的产品里,无需事先通知):

if ( ! function_exists( 'get_cravatar_url' ) ) {
/**
*替换Gravatar头像为Cravatar头像
*
* @param string $url
*
* @return string
*/
function get_cravatar_url( $url ) {
$sources = array(
'www.gravatar.com',
'0.gravatar.com',
'1.gravatar.com',
'2.gravatar.com',
'secure.gravatar.com',
'cn.gravatar.com'
);


return str_replace( $sources, 'cravatar.cn', $url );
}


add_filter( 'um_user_avatar_url_filter', 'get_cravatar_url', 1 );
add_filter( 'bp_gravatar_url', 'get_cravatar_url', 1 );
add_filter( 'get_avatar_url', 'get_cravatar_url', 1 );
}

如果你使用其他系统,想集成Cravatar头像,则可以参考我们的开发文档:https://cravatar.cn/developers

如何上传自己的头像

在Cravatar官网:https://cravatar.cn 注册账号(与litepress.cn账号互通)即可添加和更换头像,头像修改后会在5分钟内刷新缓存并生效。

附录

Cravatar.cn目前作为一款主题运行在LitePress.cn平台之上,你可以在GitHub上找到其源码:

https://github.com/litepress/litepress.cn/tree/main/wp-content/themes/cravatar

你可以随意复制、分发、重构整个LitePress相关项目的任何代码,而不用付出任何成本或承担任何法律风险。

QQ头像匹配服务至少未来3天内不可用,因为用于从邮箱哈希值匹配QQ号而生成的彩虹表达到了600G,需要一定时间导入数据库。

QQ头像自动匹配已可用

------本页内容已结束,喜欢请分享------

感谢您的来访,获取更多精彩文章请收藏本站。

© 版权声明
THE END
文章不错?点个赞呗
点赞0 分享
评论 抢沙发

请登录后发表评论

    暂无评论内容