时间:2021-05-22
垃圾留言俗称 Spam,就是到处在留言框里发垃圾广告的那些,相信大多数人都见识过。以前使用 WordPress 的时候,因为装了防 Spam 的插件,可以屏蔽掉绝大多数的 Spam。但是自从上个月从 WordPress 迁移到新的博客平台后,第一天上线就遭遇了几个Spam,全都是国外的推广的广告什么的。博客的访问量本身就很小,如果每天都来几条 Spam,太煞风景了,手工删除也太浪费时间,而且又是自己写的小系统,也不可能有什么插件可选,只能自己想办法解决了。
看到有很多网站都是加个验证码来解决这个问题的,因为 Spam 很难从图片中识别出正确的验证码,但是对于正常的留言者来说,又凭空多了一个步骤,那么除此之外还有什么方法能屏蔽这些 Spam 呢?
仔细分析一下,正常的留言应该是人类通过浏览器提交数据到我们的服务器,而 Spam 通常都是由固定的程序在互联网上扫描评论表单,伪造表单中的数据,然后判断表单的action,然后将数据 POST 到这个action上来。也就是说,Spam 发送方都没有正常地通过浏览器访问过我们的表单页面,也就是说,页面上的 JavaScript 都没有执行过咯,明白这个特点,那问题就迎刃而解了。
首先,我们可以在表单中放一个隐藏的文本框,这个文本框对正常用户来说是不可见的:
<div style="margin:0;padding:0;display:inline"> <input id="checkspam" name="checkspam" type="hidden" value="Hello Ruby" /></div>然后再写一小段 JavaScript 代码来改变这个文本框的值:
jQuery(document).ready(function($) { $("#checkspam").val('abcdefg');});由于对于 Spam 发送者来说,这段 JavaScript 是没有被执行的,那么接下来要做的事情就是在服务端判断这个隐藏文本框的值了,如果不是 JavaScript 所更改后的值,那么这条留言无疑就是 Spam 了(排除正常用户的浏览器禁用 JavaScript 的情况)。
下面以 Ruby on Rails 应用为例:
if params[:checkspam] == "abcdefg" @comment.saveelse # It's a spam...end其实,这个隐藏文本框的作用跟验证码是一样的,只不过这个验证码是由 JavaScript 帮忙自动输入了。
用了这个方法至今一月有余,目前没有再发生过 Spam 的情况。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
iphone手机频繁收到垃圾短信怎么办?有没有屏蔽方法?今天小编带来iphone苹果手机一键屏蔽iMessage垃圾短信骚扰方法,希望对大家有所帮助。iphon
近日有一些小伙伴咨询小编关于苹果7plus怎么屏蔽垃圾短信呢?下面就为大家带来了在苹果7plus中屏蔽垃圾短信的详细过程,有需要的朋友快来看看吧!。苹果7plu
三星note9中如何屏蔽垃圾短信?用户使用三星note9手机的时候会受到一些垃圾短信,这些短信要如何的屏蔽呢?在接下来的文章中小编将会带来详细的操作步骤,需要的
1、评论其他博客这个方法是我在建立博客后不久发现的,当时我的博客没有人气,也没有什么流量。有天,我在一个博客留言,寻求帮助,那位博主后来回访了我的博客。所以,一
做网站公司网络曾经在一个朋友的博客看到一个效果蛮不错的的。就是当你在其博客回复过,或者留言过。COOKIE记录你留言的用户名,而你下次访问的时候,其博客的TIT