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 相关文章推荐
不能再简单的无闪刷新验证码原理很简单
Nov 05 Javascript
js将当前时间格式转换成时间搓(自写)
Sep 26 Javascript
node.js中的fs.truncate方法使用说明
Dec 15 Javascript
JavaScript动态创建link标签到head里的方法
Dec 22 Javascript
JS设置网页图片vspace和hspace属性的方法
Apr 01 Javascript
AngularJS转换响应内容
Jan 27 Javascript
解决BootStrap Fileinput手机图片上传显示旋转问题
Jun 01 Javascript
jQuery实现的表格前端排序功能示例
Sep 18 jQuery
详解webpack中的hash、chunkhash、contenthash区别
Jan 05 Javascript
three.js实现圆柱体
Dec 30 Javascript
Layui实现数据表格中鼠标悬浮图片放大效果,离开时恢复原图的方法
Sep 11 Javascript
微信小程序单选框自定义赋值
May 26 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
全国FM电台频率大全 - 2 天津市
2020/03/11 无线电
关于页面优化和伪静态
2009/10/11 PHP
Laravel 5 框架入门(四)完结篇
2015/04/09 PHP
PHPStrom中实用的功能和快捷键大全
2015/09/23 PHP
php打开本地exe程序,js打开本地exe应用程序,并传递相关参数方法
2018/02/06 PHP
电子商务网站上的常用的js放大镜效果
2011/12/08 Javascript
javascript内存管理详细解析
2013/11/11 Javascript
JavaScript中的toLocaleLowerCase()方法使用详解
2015/06/06 Javascript
Nodejs+Socket.io实现通讯实例代码
2017/02/13 NodeJs
vue使用watch 观察路由变化,重新获取内容
2017/03/08 Javascript
Bootstrap表格制作代码
2017/03/17 Javascript
JavaScript实现实时更新系统时间的实例代码
2017/04/04 Javascript
Bootstrap里的文件分别代表什么意思及其引用方法
2017/05/01 Javascript
Bootstrap Table快速完美搭建后台管理系统
2017/09/20 Javascript
浅谈vue中慎用style的scoped属性
2017/11/28 Javascript
红黑树的插入详解及Javascript实现方法示例
2018/03/26 Javascript
JS实现同一DOM元素上onClick事件与onDblClick事件并存的解决方法
2018/06/07 Javascript
vue基本使用--refs获取组件或元素的实例
2019/11/07 Javascript
小程序跨页面交互的作用与方法详解
2020/01/07 Javascript
[01:25]DOTA2超级联赛专访iG 将调整状态找回自己
2013/06/05 DOTA
python中实现指定时间调用函数示例代码
2017/09/08 Python
python实现mysql的读写分离及负载均衡
2018/02/04 Python
python3爬虫之设计签名小程序
2018/06/19 Python
python tkinter库实现气泡屏保和锁屏
2019/07/29 Python
flask框架jinja2模板与模板继承实例分析
2019/08/01 Python
python不使用for计算两组、多个矩形两两间的iou方式
2020/01/18 Python
使用OpenCV实现道路车辆计数的使用方法
2020/07/15 Python
使用css3实现超炫的loading加载动画效果
2014/05/07 HTML / CSS
销售工作岗位职责
2013/12/24 职场文书
《生命的药方》教学反思
2014/04/08 职场文书
中国梦主题教育活动总结
2014/05/05 职场文书
简历自荐信范文
2015/03/09 职场文书
2015年企业员工工作总结范文
2015/05/21 职场文书
大学生各类奖学金申请书
2019/06/24 职场文书
MongoDB安装使用并实现Python操作数据库
2021/06/28 MongoDB
js中Map和Set的用法及区别实例详解
2022/02/15 Javascript