Valine是一个基于LeanCloud的评论系统,在很长的一段时间里,一直作为多说、GitalkGitment等等的一个替代品,博主所使用的评论系统实际上就是Valine,虽然独立博客的整体活跃度无法媲美专业博客,可还是想在这纷扰的世界里有自己的一方天地啊。多说评论的关闭,某种意义上来说,是很多90后站长们关于互联网的集体记忆,因为从博主搭建第一个WordPress博客的时候,多说就一直作为首选的评论系统而存在。那个时候通过多说就能接入主流的社交媒体,对于一个还不大会编写Web应用的博主来说,此刻想来实在是有种时过境迁的感觉。所以,Valine作为一个相当优秀的评论系统,凭借着简洁大方的界面和开箱即用的优势,在这个时间点进入人们的视野,我们就不难理解,为什么它会成为博客作者们的“新宠”。

Valine本身是利用LeanCloud的数据存储SDK来实现评论的读写的,所以,它相对于“多说”这种第三方的服务,在数据安全性上更有保障一点,虽然“多说”在关闭评论服务以前,提供了导出JSON格式评论信息的功能。可话说回来,以国内这种“敏感”的网络环境,其实没有一家云服务提供商敢打这样的包票,像阿里云、LeanCloud、七牛云存储这些服务,都曾经出现过宕机或者封杀域名的事情,所以,趁着数据还在自己手上,尽可能地做好备份工作吧!Valine本身并没有提供评论推送的功能,我还是挺怀念过去“多说”推送评论到邮箱的功能。虽然Valine-Admin这个项目提供了类似的功能,但我感觉使用起来并不顺手,尤其是配置邮箱的时候,国内像QQ、163这些都非常麻烦,遇到一两个废弃的手机号,你就会发现短信验证码,是件多么尴尬而繁琐的事情,如同扫码使用的共享电话一般魔幻。

为了解决这个问题,我想到了Valine搭配Server酱实现评论推送的方案。首先,Valine是基于LeanCloud而开发的,用户发表评论实际上就是向Comment表插入记录。因此,我们可以利用LeanCloud提供的Hooks来捕获写入评论的事件。所谓“Hooks”呢,通俗地说就是数据库里触发器的概念,我们可以在数据写入前后做点“小动作”。而Server酱则是一个消息推送服务,它提供了一个基于HTTP的请求接口,通过这个接口,我们就能实现向微信推送消息,前提是关注“方糖”公众号。关于Server酱的原理大家可以进一步去看它的文档,我们这里只需要考虑怎么样把它们结合起来,这就是工程师和科学家的区别所在[doge]。

运行在Valine云引擎中代码
运行在Valine云引擎中代码

LeanCloud提供了一个称作“云引擎”的环境,它可以提供运行比如Nodejs、Python等等的环境,实际上,Valine-Admin这个项目就是用Nodejs编写的,你可以理解为,只要你的应用符合它的规范,就能在它的环境里运行,这就是所谓的“FAAS”(函数即软件)和“BAAS”(后端即软件)。所以,说白了我们就是想利用它这个“云引擎”来调用Server酱的接口,幸运的是,LeanCloud提供的Hooks目前是支持Nodejs的,所以,到这里思路就非常清晰了,我们给Comment这张表加一个AfterSave类型的Hooks,在保存完以后调用Server酱接口推送评论信息即可。创建Hooks是在部署->云引擎选项下,我们来看下面的代码:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
AV.Cloud.afterSave('Comment', async function(request) {
var http = require("request");

var obj = request.object;
console.log('收到一条新的评论:' + JSON.stringify(obj));

var title = "收到一条新的评论";
var url = request.object.get('url');
var nick = obj.get('nick');
if (nick == 'Anonymous'){
nick = '陌生人';
}
var comment = obj.get('comment');

var content = nick + "给你留言:\n\n" + comment + "\n\n详情请访问:\n\n" + url;
var options = { method: 'GET',
url: 'https://sc.ftqq.com/<在这里输入你的token>.send',
qs: {
text: title,
desp: content
},
headers: { }
};

http(options, function (error, response, body) {
if (error) throw new Error(error);
console.log(body);
});
});

这里主要利用了Nodejs中的requests模块来发送HTTP请求,其中token是Server酱经过Github授权以后获得的,具体可以参考Server酱的文档。这里有一点要注意,Comment表里的记录是无法区分发出人的,因为有时候我们可能忘记填写邮箱或者昵称,所以,目前只要写入记录都会发送消息到手机。这个消息模板是Server酱作者提供的,我们无法对它的样式进行自定义,收到消息以后需要点击查看详情。不过,我认为这个方案可以满足我的日常使用,因为博客的评论数量并不多,而Servet酱的接口调用次数完全足够。免费的LeanCloud实例虽然会强制休眠,只要大部分时间能覆盖到就可以啦,谁让这些东西都是免费的呢,博主表示已经相当知足啦,哈哈!好了,看看消息推送到手机的效果吧!

博客评论推送到手机上的展示效果
博客评论推送到手机上的展示效果

如果大家想调整消息的格式,参考文章中给出的代码即可,每次调整完可以直接部署到线上,这是我在这个过程中体验到的Serverless的魅力,相比我们中华田园式的996敏捷开发,这种方式真的能缩短部署的周期。我还是那句话,敏捷开发是大家一起敏捷,不是只有开发苦哈哈地加班加点干活,快速交付的前提是基础设施完善,具备自动化测试、自动化部署的能力,让开发安心地写代码比什么都重要,就像LeanCloud里提供的云函数和Hooks,开发写完代码就能自动部署,这是真正的敏捷、真正的灵活。好了,这篇博客就先写到这里。想试试博主能不能第一时间收到你们的留言?欢迎在博客评论区留下你的足迹,谢谢大家!