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 相关文章推荐
js tab 选项卡
Apr 26 Javascript
Javascript学习笔记9 prototype封装继承
Jan 11 Javascript
DOM节点深度克隆函数cloneNode()用法实例
Jan 12 Javascript
AngularJS基础 ng-repeat 指令简单示例
Aug 03 Javascript
Vue2.x中的父组件传递数据至子组件的方法
May 01 Javascript
使用Electron构建React+Webpack桌面应用的方法
Dec 15 Javascript
javascript中的replace函数(带注释demo)
Jan 07 Javascript
利用weixin-java-miniapp生成小程序码并直接返回图片文件流的方法
Mar 29 Javascript
JavaScript实现的联动菜单特效示例
Jul 08 Javascript
JavaScript实现简单的图片切换功能(实例代码)
Apr 10 Javascript
Javascript幻灯片播放功能实现过程解析
May 07 Javascript
JavaScript实现猜数字游戏
May 20 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
用libTemplate实现静态网页的生成
2006/10/09 PHP
深入理解PHP中的global
2014/08/19 PHP
PHP 5.3和PHP 5.4出现FastCGI Error解决方法
2015/02/12 PHP
PHP关键特性之命名空间实例详解
2017/05/06 PHP
PHP中quotemeta()函数的用法讲解
2019/04/04 PHP
jquery获取tr中控件值并操作tr实现思路
2013/03/27 Javascript
JavaScript 函数惰性载入的实现及其优点介绍
2013/08/12 Javascript
JS操作JSON要领详细总结
2013/08/25 Javascript
js复制网页内容并兼容各主流浏览器的代码
2013/12/17 Javascript
javascript中错误使用var造成undefined
2016/03/31 Javascript
全面解析多种Bootstrap图片轮播效果
2016/05/27 Javascript
浅谈javascript中的加减时间
2016/07/12 Javascript
JavaScript SHA512加密算法详细代码
2016/10/06 Javascript
AngularJS变量及过滤器Filter用法分析
2016/11/22 Javascript
javascript中的面向对象
2017/03/30 Javascript
LayUi中接口传数据成功,表格不显示数据的解决方法
2018/08/19 Javascript
基于layui内置模块(element常用元素的操作)
2019/09/20 Javascript
python备份文件以及mysql数据库的脚本代码
2013/06/10 Python
Python高级应用实例对比:高效计算大文件中的最长行的长度
2014/06/08 Python
进一步探究Python中的正则表达式
2015/04/28 Python
Flask框架的学习指南之用户登录管理
2016/11/20 Python
用 Python 爬了爬自己的微信朋友(实例讲解)
2017/08/25 Python
python实现拓扑排序的基本教程
2018/03/11 Python
详解python 模拟豆瓣登录(豆瓣6.0)
2019/04/18 Python
python实现画出e指数函数的图像
2019/11/21 Python
使用PyOpenGL绘制三维坐标系实例
2019/12/24 Python
在TensorFlow中屏蔽warning的方式
2020/02/04 Python
python统计字符的个数代码实例
2020/02/07 Python
使用Django实现把两个模型类的数据聚合在一起
2020/03/28 Python
canvas之万花筒效果的简单实现(推荐)
2016/08/16 HTML / CSS
在网上学习全世界最好的课程:Coursera
2017/11/07 全球购物
快时尚眼镜品牌,全国连锁眼镜店:LOHO眼镜生活
2018/10/08 全球购物
《桂林山水》教学反思
2014/02/08 职场文书
元旦晚会主持词
2014/03/24 职场文书
2016年社区国庆节活动总结
2016/04/01 职场文书
聊聊JS ES6中的解构
2021/04/29 Javascript