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 中document.URL 和 windows.location.href 的区别
Nov 11 Javascript
document.documentElement的一些使用技巧
Apr 18 Javascript
from表单多个按钮提交用onclick跳转不同action
Apr 24 Javascript
使用JavaScript的AngularJS库编写hello world的方法
Jun 23 Javascript
谈谈encodeURI和encodeURIComponent以及escape的区别与应用
Nov 24 Javascript
JavaScript学习笔记之ES6数组方法
Mar 25 Javascript
AngularJS基础 ng-focus 指令简单示例
Aug 01 Javascript
微信小程序开发图片拖拽实例详解
May 05 Javascript
在vue-cli脚手架中配置一个vue-router前端路由
Jul 03 Javascript
简单实现jQuery轮播效果
Aug 18 jQuery
jquery动态添加以及遍历option并获取特定样式名称的option方法
Jan 29 jQuery
vue踩坑记录之数组定义和赋值问题
Mar 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
PHP setcookie设置Cookie用法(及设置无效的问题)
2011/07/13 PHP
php 批量替换程序的具体实现代码
2013/10/04 PHP
Laravel5.1数据库连接、创建数据库、创建model及创建控制器的方法
2016/03/29 PHP
Laravel中encrypt和decrypt的实现方法
2017/09/24 PHP
JQuery 实现的页面滚动时浮动窗口控件
2009/07/10 Javascript
Jquery 高亮显示文本中重要的关键字
2009/12/24 Javascript
javascript SpiderMonkey中的函数序列化如何进行
2012/12/05 Javascript
JQuery触发事件例如click
2013/09/11 Javascript
如何用jquery控制表格奇偶行及活动行颜色
2014/04/20 Javascript
jQuery选择器源码解读(三):tokenize方法
2015/03/31 Javascript
移动端JQ插件hammer使用详解
2015/07/03 Javascript
JavaScript实现点击按钮切换网页背景色的方法
2015/10/17 Javascript
jquery解析json格式数据的方法(对象、字符串)
2015/11/24 Javascript
Node.js静态文件服务器改进版
2016/01/10 Javascript
AngularJS基础 ng-init 指令简单示例
2016/08/02 Javascript
Javascript中的 “&amp;” 和 “|” 详解
2017/02/02 Javascript
JS简单实现获取元素的封装操作示例
2017/04/07 Javascript
vue.js中proxyTable 转发请求的实现方法
2018/09/20 Javascript
vue elementui el-form rules动态验证的实例代码详解
2019/05/23 Javascript
深入了解js原型模式
2019/05/30 Javascript
vue - vue.config.js中devServer配置方式
2019/10/30 Javascript
vue-cli3.0实现一个多页面应用的历奇经历记录总结
2020/03/16 Javascript
Vue路由权限控制解析
2020/11/09 Javascript
uniapp微信小程序:key失效的解决方法
2021/01/20 Javascript
python发布模块的步骤分享
2014/02/21 Python
python实现字符串和字典的转换
2018/09/29 Python
Python读取txt内容写入xls格式excel中的方法
2018/10/11 Python
python列表返回重复数据的下标
2020/02/10 Python
Python3开发环境搭建详细教程
2020/06/18 Python
基于HTML5的WebSocket的实例代码
2018/08/15 HTML / CSS
工程造价专业大学生自荐信
2013/10/01 职场文书
老师推荐信
2013/10/28 职场文书
幼儿园消防安全制度
2014/01/26 职场文书
2014年辅导员工作总结
2014/11/18 职场文书
单位考核鉴定意见
2015/06/05 职场文书
Java实现贪吃蛇游戏的示例代码
2022/09/23 Java/Android