jquery中防刷IP流量软件影响统计的一点对策


Posted in Javascript onJuly 10, 2011

遭遇刷IP、刷流量软件的困扰

      本以为有效控制同一天对同一个IP仅算一次的方案就能有效防止用户多次刷新地址作弊的现象,我得承认涉世未深孤陋寡闻 - -,一直忽视现在的刷流量软件如此的强大,我们的项目也遭遇使用刷流量软件的情况,因而产生不少垃圾数据,甚至影响统计的准确性。

      为解决这种情况也特意下载了两款知名度比较高的刷流量软件“流量宝”和“流量精灵”了解一下,不用不知道,一用确实是个好东西。

      这两款软件的原理都一样,估计其它的也差不多吧,就是利用网络互访原理,利用网络节点地域差异性,用户随机性,使访问效果真实有效,也就是你的电脑挂着一个刷流量的软件的时候,你的地址会被也在挂机的所有用户访问,当然人家帮你刷的同时你也在帮人家刷,这一切功夫软件都在背后帮你完成,挂上几分钟马上就能看到流量慢慢上来,说了不少废话,下面也说说对策。

应对方案

      鉴于部分网友不喜欢看全文就下断论的情况,这里强调一下,所有提交的后台的数据都有做IP检查的,而本文讨论的就是基于这种情况下被刷IP的应对方案。

      方案一:通过Ajax异步提交数据(无效)

      起初推广地址被点击时在后台解析页面是会先记录访客的IP、时间等信息,这种方式显然很难防不了刷流量软件,因此便考虑通过Ajax异步提交数据的形式。

      刚开始还是低估这些流氓软件,以为只是通过简单的模拟http请求不会触发js脚本,所以第一种方案是通过页面加载完成后,通过ajax异步提交记录请求,结果无效,实验证明此方式仅对比较低级的机器人有效;

      方案二:判断请求的客户端浏览器窗口宽度或高度(无效)

      通过方案一可推测这些流量软件不是单纯的模拟http请求, 也就是通过真实的浏览器请求的,但我挂机“被”帮别人刷流量的同时,并未看到任何网页的打开,只能通过抓包工具看到不停的请求,那我猜想这些刷流量软件是不是隐藏了一个浏览器窗口,或者将浏览器窗口设置得很小很小……对此猜想我通过js判断客户端当前打开的浏览器窗口区域是否大于某个值(如宽300px,高200px,相信没什么人会用这么小的区域看网站吧~),超过一个下限值才通过Ajax提交数据。

      结果还是无效,对此也特意写了小程序记录每一个请求的浏览器类型、窗口大小……,结果令我无语,请求的浏览器可视区域都很正常,甚至分辨率很多比我的显示器还高,自我鄙视ing……

      方案三: 通过鼠标事件作为正常访问的依据有效

      通过几番试验,得出的结论是这些机器人并不简单,但毕竟是机器人,那就考虑通过鼠标事件判断是否机器人,如mousemove、mousedown、mouseover等,当然也可以通过让用户选择点击按钮等认为操作作判断依据(当然要考虑操作体验好不好),下面放个简单脚本:

<script src="jquery-1.4.1.min.js" type="text/javascript"></script> 
<script language="javascript" type="text/javascript"> 
$(document).ready(function() { 
var movetimes = 0; //移动次数 
$(document).mousemove(function(even) { 
movetimes++; 
if (movetimes > 100) { //事件被执行次数大于n,设置个比较保守的值 
$(document).unbind("mousemove"); //解除mousemove绑定 
//此处执行异步提交数据 
alert("异步提交记录请求!"); 
} 
}); 
}); 
</script>

总结:

经过多番尝试,最终在第三种方案取得成效,但也不排除日后这些机器人的不断改进而攻破这个简单检验环节,毕竟道高一尺魔高一丈。但机器人毕竟是机器人,不妨多增加点人为操作的条件因素作判断,估计还是能防止这类刷IP流量软件影响统计的。可能由于项目的特殊性,这些方案并不一定适合所有的情形,毕竟这些刷流量软件大多都是些草根站长使用并且通常都是刷自己的网站的:),这里也希望院子里的网友也提提好的建议,如何应对这些刷流量软件,分享下经验。

Javascript 相关文章推荐
JavaScript 对象、函数和继承
Jul 07 Javascript
DOM和XMLHttpRequest对象的属性和方法整理
Jan 04 Javascript
html文件中jquery与velocity变量中的$冲突的解决方法
Nov 01 Javascript
移动设备web开发首选框架:zeptojs介绍
Jan 29 Javascript
Node.js + Redis Sorted Set实现任务队列
Sep 19 Javascript
AngularJS中的JSONP实例解析
Dec 01 Javascript
VUE axios上传图片到七牛的实例代码
Jul 28 Javascript
基于jQuery对象和DOM对象和字符串之间的转化实例
Aug 08 jQuery
原生JS实现的轮播图功能详解
Aug 06 Javascript
对angularJs中$sce服务安全显示html文本的实例
Sep 30 Javascript
javascript如何实现create方法
Nov 04 Javascript
vue项目支付功能代码详解
Feb 18 Vue.js
让你的CSS像Jquery一样做筛选的实现方法
Jul 10 #Javascript
基于jquery的使ListNav兼容中文首字拼音排序的实现代码
Jul 10 #Javascript
使用Jquery搭建最佳用户体验的登录页面之记住密码自动登录功能(含后台代码)
Jul 10 #Javascript
JQuery 自定义CircleAnimation,Animate方法学习笔记
Jul 10 #Javascript
关于jQuery中的end()使用方法
Jul 10 #Javascript
动感效果的TAB选项卡jquery 插件
Jul 09 #Javascript
使用Jquery打造最佳用户体验的登录页面的实现代码
Jul 08 #Javascript
You might like
set_include_path在win和linux下的区别
2008/01/10 PHP
win7计划任务定时执行PHP脚本设置图解
2014/05/09 PHP
PHP unset函数原理及使用方法解析
2020/08/14 PHP
推荐自用 Javascript 缩图函数 (onDOMLoaded)……
2007/10/23 Javascript
解决表单中第一个非隐藏的元素获得焦点的一个方案
2009/10/26 Javascript
jQuery的初始化与对象构建之浅析
2011/04/12 Javascript
js实现屏蔽默认快捷键调用自定义事件示例
2013/06/18 Javascript
js操纵dom生成下拉列表框的方法
2014/02/24 Javascript
让alert不出现弹窗的两种方法
2014/05/18 Javascript
详解Javascript动态操作CSS
2014/12/08 Javascript
jQuery的position()方法详解
2015/07/19 Javascript
javascript实现输出指定行数正方形图案的方法
2015/08/03 Javascript
js实现文本框输入文字个数限制代码
2015/12/25 Javascript
AngularJS 避繁就简的路由
2016/07/01 Javascript
JS实现的表头列头固定页面功能示例
2017/01/10 Javascript
JScript实现地址选择功能
2017/08/15 Javascript
原生js实现获取form表单数据代码实例
2019/03/27 Javascript
JavaScript函数式编程(Functional Programming)声明式与命令式实例分析
2019/05/21 Javascript
Vuex 模块化使用详解
2019/07/31 Javascript
Python抓取电影天堂电影信息的代码
2016/04/07 Python
Python实现二分查找与bisect模块详解
2017/01/13 Python
python算法与数据结构之单链表的实现代码
2019/06/27 Python
DJANGO-URL反向解析REVERSE实例讲解
2019/10/25 Python
python 错误处理 assert详解
2020/04/20 Python
python opencv实现简易画图板
2020/08/27 Python
Python unittest discover批量执行代码实例
2020/09/08 Python
纯HTML5+CSS3制作图片旋转
2016/01/12 HTML / CSS
迪卡侬印度官网:购买所有体育用品
2017/06/24 全球购物
简单说下OSPF的操作过程
2014/08/13 面试题
电子信息毕业生自荐信
2013/11/16 职场文书
大学毕业感言一句话
2014/02/06 职场文书
庐山导游词
2015/02/03 职场文书
政协常委会议主持词
2015/07/03 职场文书
承诺书的内容有哪些,怎么写?
2019/06/21 职场文书
高考满分作文赏析(2篇)
2019/08/12 职场文书
MySQL创建表操作命令分享
2022/03/25 MySQL