从刷票了解获得客户端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 相关文章推荐
Zend引擎的发展 [15]
Oct 09 PHP
模仿OSO的论坛(四)
Oct 09 PHP
IIS6+PHP5+MySQL5+Zend Optimizer+phpMyAdmin安装配置图文教程 2009年
Jun 08 PHP
php权重计算方法代码分享
Jan 09 PHP
php面向对象中的魔术方法中文说明
Mar 04 PHP
php中使用session_set_save_handler()函数把session保存到MySQL数据库实例
Nov 06 PHP
PHP读取大文件末尾N行的高效方法推荐
Jun 03 PHP
PHP实现的网站目录扫描索引工具
Sep 08 PHP
Yii框架弹出框功能示例
Jan 07 PHP
PHP基于redis计数器类定义与用法示例
Feb 08 PHP
PHP 中 var_export、print_r、var_dump 调试中的区别
Jun 19 PHP
Yii框架函数简单用法分析
Sep 09 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
php正则表达式(regar expression)
2011/09/10 PHP
PHP多态代码实例
2015/06/26 PHP
PHP接收json 并将接收数据插入数据库的实现代码
2015/12/01 PHP
PHP实现移除数组中为空或为某值元素的方法
2017/01/07 PHP
简短几句jquery代码的实现一个图片向上滚动切换
2011/09/02 Javascript
JavaScript strike方法入门实例(给字符串加上删除线)
2014/10/17 Javascript
JavaScript比较两个对象是否相等的方法
2015/02/06 Javascript
JavaScript中Math.SQRT2属性的使用详解
2015/06/14 Javascript
跟我学习javascript解决异步编程异常方案
2015/11/23 Javascript
学习JavaScript设计模式(接口)
2015/11/26 Javascript
vue,angular,avalon这三种MVVM框架优缺点
2016/04/27 Javascript
Javascript 6里的4个新语法
2016/08/25 Javascript
深入学习Bootstrap表单
2016/12/13 Javascript
你不知道的 javascript【推荐】
2017/01/08 Javascript
Bootstrap弹出框(Popover)被挤压的问题小结
2017/07/11 Javascript
vue-router相关基础知识及工作原理
2018/03/16 Javascript
bootstrap+spring boot实现面包屑导航功能(前端代码)
2019/10/09 Javascript
详解node和ES6的模块导出与导入
2020/02/19 Javascript
Python的ORM框架SQLAlchemy入门教程
2014/04/28 Python
Python fileinput模块使用实例
2015/05/28 Python
Python操作MySQL数据库9个实用实例
2015/12/11 Python
python字符串,数值计算
2016/10/05 Python
对python中return和print的一些理解
2017/08/18 Python
PyCharm设置护眼背景色的方法
2018/10/29 Python
numpy下的flatten()函数用法详解
2019/05/27 Python
python3光学字符识别模块tesserocr与pytesseract的使用详解
2020/02/26 Python
如何通过Python3和ssl实现加密通信功能
2020/05/09 Python
Canvas多边形绘制的实现方法
2019/08/05 HTML / CSS
医院竞聘演讲稿
2014/05/16 职场文书
践行党的群众路线心得体会
2014/11/05 职场文书
2014年科普工作总结
2014/12/06 职场文书
教师听课评语大全
2014/12/31 职场文书
Python机器学习之PCA降维算法详解
2021/05/19 Python
新手入门Mysql--概念
2021/06/18 MySQL
javascript数组includes、reduce的基本使用
2021/07/02 Javascript
centos8安装nginx1.9.1的详细过程
2021/08/02 Servers