Spam, spam!!

故事 心情

Thu Feb 04 08:28:20 -0800 2010

我的博客评论被 Spam 了。

最早,我用了Scanty默认的disqus,但后来发现在不注册disqus账号的情况下发表评论极其麻烦,后来就自己实现了。没有任何Anti-Spam的机制。

某年月日,终于不知被谁盯上了,我的博客没几篇帖子,却收到百余篇评论。都是些英文的广告,像是用软件发的,来自不同IP。

加了个类似Rails中protect-from-forgery的功能,不管用。Spam软件好像能直接提交Form。

加了cookie,还是不管用,它也认识cookie。

靠!还想试试Ajax-form,难不成它也认识Javascript?不过懒得试了,我不想为这个再加个jQuery的库。

用图片做验证码?得在服务器端生成,麻烦,用户体验也不好。

虽然我的博客没几个读者,但来者是客,我希望他们能简简单单发表评论,随便留个名就行。但,我怎么区分Spam啊?

好像有个服务(忘名字了),能认识大部分Spam的关键字,需要装个Gem,每次都需要发请求检查,浪费。

最后,我还是用了个笨办法:

真正的读者,打开帖子后肯定不会立即发表评论,从阅读、写评论,到提交,肯定需要一些时间。我假定这段时间是40秒。如果在40秒内我收到评论,就认为是Spam(Spam软件运行起来都是很快的)。

用了几天,效果还不错。偶有漏网之鱼,不过,我相信99%都挡住了。剩下的手工删。

那么,40秒的时间是否挡住了我真正的读者?我不知道。我只希望这是一个合情合理的时间。如果你在提交时看到类似“Spam detected”之类的提示,请刷新重试。

这算是好的用户体验吗?


本文地址:http://www.dujinfang.com/past/2010/2/4/spam-spam/
短地址:

-------------------------------------------------------------------------------------------
GL at Thu Feb 04 18:04:54 -0800 2010:

<p>你这个功能不好使啊</p>
gary at Thu Feb 04 18:18:24 -0800 2010:
<p>好主意,别Spam我。</p>
呵呵 at Sat Feb 06 04:52:27 -0800 2010:
<p>呵呵.我不知道</p>
miss at Tue Feb 23 19:25:08 -0800 2010:
<p>看你博文,不懂又感兴趣的,去网上查下,多多少少都有所收获。呵呵。</p>
给我留言 | Leave a comment
------ ^_^ ------------------------------------------------------------------------7-------
名字|Your Name *required

邮件|Your Email *required but won't show

网站|Your Website -optional

空白|Blank Leave me blank if you are a live person

留言|Comment