从刷票了解获得客户端IP的方法


Posted in PHP onSeptember 21, 2015

前两个星期帮一个朋友的亲戚的孩子刷票,谁让咱们是程序员呢。这当中也遇到过重装系统,除灰尘,淘宝购物,盗QQ,下电影,某一个软件为什么不能使用等等,要是说不会,他们就说你电脑技术不是挺牛逼的吗,这点问题都解决不了。

刷票,分为多种限制,注册用户,验证码,以及IP限制。这个刷票网站,而不,是这个投票网站,限制了IP。如果要突破限制,我们需要了解如何获得用户的IP。

getenv('HTTP_X_FORWARDED_FOR')
getenv('HTTP_CLIENT_IP')
getenv('REMOTE_ADDR')

HTTP_X_FORWARDED_FOR

这个是从http header头部获得,他的格式是A ip, B ip, C ip。出现这种情况的原因有两种

一个网站由于流量过大,使用负载均衡,所以在应用程序前面放一个负载均衡器,用户无法直接访问到。
用户使用代理去访问。
用户先是使用A IP,每增加一层代理,这个头就会在后面多增加一个IP,以逗号分割,最后到达真正的web容器。 只要是头部获得信息,都是可以被伪造的。所以这种情况使用A IP 有可能不是用户的真实IP。所以我们这种情况,我们只能把连接负载均衡的IP当做用户的真实IP,至少这个数据是正确的。但是这个IP可能是用户的代理IP,不是用户的真实IP。不过这种情况至少比用户的假ip好一些。

HTTP_CLIENT_IP

这个也是从header头部获得,本来是打算记录用户真实IP,但是很少使用到。

REMOTE_ADDR

这个就是获得连接的IP,只有小网站才这么使用,直接把数据暴漏出去,站点就是一个单点,没有任何的负载均衡。如果上层使用了pxory,这个数据就是proxy的IP。

而我作恶就是直接伪造x-forwarder-for数据,然后欺骗他们,不过没过几天,这个漏洞被发现了,然后我就换成使用代理的方式的直接刷的。

PHP 相关文章推荐
ThinkPHP php 框架学习笔记
Oct 30 PHP
php数组中删除元素的实现代码
Jun 22 PHP
浅谈php扩展imagick
Jun 02 PHP
php中base64_decode与base64_encode加密解密函数实例
Nov 24 PHP
纯PHP代码实现支付宝批量付款
Dec 24 PHP
php中json_encode不兼容JSON_UNESCAPED_UNICODE的解决方案
May 31 PHP
Yii数据读取与跳转参数传递用法实例分析
Jul 12 PHP
php实现带读写分离功能的MySQL类完整实例
Jul 28 PHP
PHP给前端返回一个JSON对象的实例讲解
May 31 PHP
ThinkPHP6.0如何利用自定义验证规则规范的实现登陆
Dec 16 PHP
如何在Mac上通过docker配置PHP开发环境
May 29 PHP
浅谈Laravel中使用Slack进行异常通知
May 29 PHP
fsockopen pfsockopen函数被禁用,SMTP发送邮件不正常的解决方法
Sep 20 #PHP
分享ThinkPHP3.2中关联查询解决思路
Sep 20 #PHP
使用PHPCMS搭建wap手机网站
Sep 20 #PHP
求帮忙修改个php curl模拟post请求内容后并下载文件的解决思路
Sep 20 #PHP
PHP执行SQL文件并将SQL文件导入到数据库
Sep 17 #PHP
如何使用PHP对网站验证码进行破解
Sep 17 #PHP
浅谈php+phpStorm+xdebug配置方法
Sep 17 #PHP
You might like
用Socket发送电子邮件(利用需要验证的SMTP服务器)
2006/10/09 PHP
PHP生成静态页
2006/11/25 PHP
PHP 数组教程 定义数组
2009/10/23 PHP
php读取der格式证书乱码解决方法
2015/06/22 PHP
Windows平台实现PHP连接SQL Server2008的方法
2017/07/26 PHP
javascript AOP 实现ajax回调函数使用比较方便
2010/11/20 Javascript
用jquery修复在iframe下的页面锚点失效问题
2014/08/22 Javascript
原创jQuery弹出层插件分享
2015/04/02 Javascript
Jquery全选与反选点击执行一次的解决方案
2015/08/14 Javascript
更高效的使用JQuery 这里总结了8个小技巧
2016/04/13 Javascript
微信小程序使用第三方库Underscore.js步骤详解
2016/09/27 Javascript
Node.js常用工具之util模块
2017/03/09 Javascript
react性能优化达到最大化的方法 immutable.js使用的必要性
2017/03/09 Javascript
jQuery+Ajax请求本地数据加载商品列表页并跳转详情页的实现方法
2017/07/12 jQuery
BootStrap的双日历时间控件使用
2017/07/25 Javascript
深入浅析vue组件间事件传递
2017/12/29 Javascript
微信二次分享报错invalid signature问题及解决方法
2019/04/01 Javascript
JS中类的静态方法,静态变量,实例方法,实例变量区别与用法实例分析
2020/03/14 Javascript
[01:24]2014DOTA2 TI第二日 YYF表示这届谁赢都有可能
2014/07/11 DOTA
Python使用Flask框架同时上传多个文件的方法
2015/03/21 Python
Windows下Anaconda的安装和简单使用方法
2018/01/04 Python
Python使用progressbar模块实现的显示进度条功能
2018/05/31 Python
浅谈pycharm使用及设置方法
2019/09/09 Python
python向图片里添加文字
2019/11/26 Python
学会迭代器设计模式,帮你大幅提升python性能
2021/01/03 Python
matplotlib绘制鼠标的十字光标的实现(自定义方式,官方实例)
2021/01/10 Python
python 基于DDT实现数据驱动测试
2021/02/18 Python
CSS3实现圆角、阴影、透明效果并兼容各大浏览器
2014/08/08 HTML / CSS
白兰氏健康Mall:BRAND’S
2017/11/13 全球购物
红头文件任命书范本
2014/06/05 职场文书
学校安全防火方案
2014/06/07 职场文书
建筑工地文明标语
2014/10/09 职场文书
导师对论文的学术评语
2015/01/04 职场文书
升职感谢信
2015/01/22 职场文书
财务会计岗位职责
2015/02/03 职场文书
未婚证明范本
2015/06/15 职场文书