从刷票了解获得客户端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 相关文章推荐
使用Apache的rewrite技术
Jun 22 PHP
一段php加密解密的代码
Oct 09 PHP
php调用mysql数据 dbclass类
May 07 PHP
php设计模式 Observer(观察者模式)
Jun 26 PHP
php中截取中文字符串的代码小结
Jul 17 PHP
ThinkPHP3.1数据CURD操作快速入门
Jun 19 PHP
PHP的伪随机数与真随机数详解
May 27 PHP
yii实现model添加默认值的方法(2种方法)
Jan 06 PHP
PHP常见错误提示含义解释(实用!值得收藏)
Apr 25 PHP
php实现多站点共用session实现单点登录的方法详解
Sep 18 PHP
PHP pthreads v3使用中的一些坑和注意点分析
Feb 21 PHP
PHP控制循环操作的时间
Apr 01 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
ThinkPHP中处理表单中的注意事项
2014/11/22 PHP
Yii2实现上下联动下拉框功能的方法
2016/08/10 PHP
php组合排序简单实现方法
2016/10/15 PHP
jQuery库与其他JS库冲突的解决办法
2010/02/07 Javascript
加载jQuery后$冲突的解决办法
2010/07/09 Javascript
jQuery版Tab标签切换
2011/03/16 Javascript
jquery事件与函数的使用介绍
2013/09/29 Javascript
javascript单例模式的简单实现方法
2015/07/25 Javascript
Angularjs中的页面访问权限怎么设置
2016/11/11 Javascript
玩转NODE.JS(四)-搭建简单的聊天室的代码
2016/11/11 Javascript
Nodejs下DNS缓存问题浅析
2016/11/16 NodeJs
JS封装通过className获取元素的函数示例
2016/12/20 Javascript
js仿百度音乐全选操作
2017/01/13 Javascript
详解vue2父组件传递props异步数据到子组件的问题
2017/06/29 Javascript
Vue学习笔记进阶篇之函数化组件解析
2017/07/21 Javascript
Angular实现的内置过滤器orderBy排序与模糊查询功能示例
2017/12/29 Javascript
node内置调试方法总结
2018/02/22 Javascript
微信小程序 wx:for遍历循环使用实例解析
2019/09/09 Javascript
node.js如何操作MySQL数据库
2020/10/29 Javascript
[00:12]2018DOTA2亚洲邀请赛SOLO赛 MidOne是否中单第一人?
2018/04/05 DOTA
让python同时兼容python2和python3的8个技巧分享
2014/07/11 Python
Python多线程编程(四):使用Lock互斥锁
2015/04/05 Python
python实现图片转字符小工具
2019/04/30 Python
python实现文件的备份流程详解
2019/06/18 Python
python框架flask表单实现详解
2019/11/04 Python
使用OpenCV对车道进行实时检测的实现示例代码
2020/06/19 Python
Python实现封装打包自己写的代码,被python import
2020/07/12 Python
德国柯吉澳趣味家居:Koziol
2017/08/24 全球购物
西班牙在线光学:Visual-Click
2020/06/22 全球购物
请用Python写一个获取用户输入数字,并根据数字大小输出不同信息的脚本
2014/05/20 面试题
硅酸盐工业控制专业应届生求职信
2013/11/02 职场文书
文秘自荐信
2014/06/28 职场文书
2015年行政工作总结范文
2015/04/09 职场文书
公司聚餐通知
2015/04/22 职场文书
单位介绍信格式范文
2015/05/04 职场文书
Canvas如何做个雪花屏版404的实现
2021/09/25 HTML / CSS