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 相关文章推荐
jQuery第三课 修改元素属性及内容的代码
Mar 14 Javascript
获取元素距离浏览器周边的位置的方法getBoundingClientRect
Apr 17 Javascript
jQuery源码分析之Callbacks详解
Mar 13 Javascript
javascript元素动态创建实现方法
May 13 Javascript
JS在Chrome浏览器中showModalDialog函数返回值为undefined的解决方法
Aug 03 Javascript
js 自带的sort() 方法全面了解
Aug 16 Javascript
JS瀑布流实现方法实例分析
Dec 19 Javascript
关于jQuery里prev()的简单操作代码
Oct 27 jQuery
JS合并两个数组的3种方法详解
Oct 24 Javascript
JavaScript正则表达式验证登录实例
Mar 18 Javascript
jQuery实现颜色打字机的完整代码
Mar 19 jQuery
JavaScript实现通讯录功能
Dec 27 Javascript
让你的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
那些年一起学习的PHP(一)
2012/03/21 PHP
探讨方法的重写(覆载)详解
2013/06/08 PHP
php 邮件发送问题解决
2014/03/22 PHP
php+mysql大量用户登录解决方案分析
2014/12/29 PHP
php导出中文内容excel文件类实例
2015/07/06 PHP
原创javascript小游戏实现代码
2010/08/19 Javascript
超酷的网页音乐播放器DewPlayer使用方法
2010/12/18 Javascript
P3P Header解决Cookie跨域的问题
2013/03/12 Javascript
JQuery对class属性的操作实现按钮开关效果
2013/10/11 Javascript
JS逆序遍历实现代码
2014/12/02 Javascript
js实现用户注册协议倒计时的方法
2015/01/21 Javascript
jQuery简单实现input文本框内灰色提示文本效果的方法
2015/12/02 Javascript
javascript实现延时显示提示框特效代码
2016/04/27 Javascript
jQuery simpleModal插件的使用介绍
2016/08/30 Javascript
用nodejs搭建websocket服务器
2017/01/23 NodeJs
微信小程序实现皮肤功能(夜间模式)
2017/06/18 Javascript
Vue Transition实现类原生组件跳转过渡动画的示例
2017/08/19 Javascript
Vue.js用法详解
2017/11/13 Javascript
web前端页面生成exe可执行文件的方法
2018/02/08 Javascript
jQuery实现基本动画效果的方法详解
2018/09/06 jQuery
vue router的基本使用和配置教程
2018/11/05 Javascript
vue 解决addRoutes多次添加路由重复的操作
2020/08/04 Javascript
Python中的ConfigParser模块使用详解
2015/05/04 Python
举例讲解Python中的算数运算符的用法
2015/05/13 Python
python中requests库session对象的妙用详解
2017/10/30 Python
Python使用Selenium爬取淘宝异步加载的数据方法
2018/12/17 Python
使用python制作一个为hex文件增加版本号的脚本实例
2019/06/12 Python
python统计函数库scipy.stats的用法解析
2020/02/25 Python
Django REST framwork的权限验证实例
2020/04/02 Python
python使用pymongo与MongoDB基本交互操作示例
2020/04/09 Python
Dr. Martens马汀博士澳大利亚官网:马丁靴鼻祖
2019/07/02 全球购物
.net C#面试题
2012/08/28 面试题
理财学专业自荐书
2014/06/28 职场文书
2015年信息宣传工作总结
2015/05/26 职场文书
谢师宴家长答谢词
2015/09/30 职场文书
2016年小学生教师节广播稿
2015/12/18 职场文书