网站地图    收藏   

主页 > php专栏 > php应用 >

php用Curl伪造客户端源IP - php高级应用

来源:自学PHP网    时间:2014-11-27 22:16 作者: 阅读:

[导读] 在网上找了很多种用Curl伪造客户端源IP的一些方法,几乎都是使用curl函数,后来查证了此函数的使用果然是强大,不但可以伪造客户端源IP还可以...

php用Curl伪造客户端源IP

在网上找了很多种用Curl伪造客户端源IP的一些方法,几乎都是使用curl函数,后来查证了此函数的使用果然是强大,不但可以伪造客户端源IP还可以伪造代理IP哦,下面我们来看看代码。

一般服务器获取客户IP有三种情况

1.在没用代理的情况下:

#http://www.phpfensi.com

REMOTE_ADDR =客户IP

HTTP_VIA = 空

HTTP_X_FORWARDED_FOR = 空

2.在使用代理且代理服务器有设置转发客户端IP的情况:

REMOTE_ADDR = 代理服务器 IP

HTTP_VIA = 代理服务器 IP

HTTP_X_FORWARDED_FOR = 客户IP

HTTP_VIA和HTTP_X_FORWARDED_FOR值可通过添加Header头自定义,进而可通过此隐藏客户端IP,前提是服务器端有启用X_FORWARDED_FOR。

测试效果,服务器端新建PHP程序.

实例代码一,代码如下

  1. <?php 
  2. $ch = curl_init(); 
  3. curl_setopt($ch, CURLOPT_URL, "http://localhost/index.php"); 
  4. curl_setopt($ch, CURLOPT_HTTPHEADER, array('X-FORWARDED-FOR:8.8.8.8''CLIENT-IP:8.8.8.8'));  
  5. //构造IP 
  6. curl_setopt($ch, CURLOPT_REFERER, "http://www.phpfensi.com/ ");   //构造来路 
  7. curl_setopt($ch, CURLOPT_HEADER, 1); 
  8. $out = curl_exec($ch); 
  9. curl_close($ch); 

实例代码二,php代码如下:

  1. <?php 
  2. function getClientIp() { 
  3.     if (!emptyempty($_SERVER["HTTP_CLIENT_IP"])) 
  4.         $ip = $_SERVER["HTTP_CLIENT_IP"]; 
  5.     else if (!emptyempty($_SERVER["HTTP_X_FORWARDED_FOR"])) 
  6.         $ip = $_SERVER["HTTP_X_FORWARDED_FOR"]; 
  7.     else if (!emptyempty($_SERVER["REMOTE_ADDR"])) 
  8.         $ip = $_SERVER["REMOTE_ADDR"]; 
  9.     else 
  10.         $ip = "err"
  11.     return $ip
  12. echo "IP: " . getClientIp() . ""
  13. echo "referer: " . $_SERVER["HTTP_REFERER"]; 
  14. echo "IP: " . getClientIp() . ""
  15. echo "referer: " . $_SERVER["HTTP_REFERER"]; 

伪造成功,这是不是给“刷票”的朋友提供了很好的换IP的方案,哈哈。

结果:

  1. HTTP/1.1 200 OK Date: Wed, 03 Apr 2013 06:20:42 GMT Server: Apache/2.2.22 (Win32) PHP/5.3.13 
  2. X-Powered-By: PHP/5.3.13 Content-Length: 44 Content-Type: text/html 
  3. IP: 8.8.8.8 

referer: http://www.phpfensi.com/

下面看关于curl函数

curl相关函数列表:

curl_init — 初始化一个CURL会话

curl_setopt — 为CURL调用设置一个选项

curl_exec — 执行一个CURL会话

curl_close — 关闭一个CURL会话

curl_version — 返回当前CURL版本

1>curl_init — 初始化一个CURL会话

自学PHP网专注网站建设学习,PHP程序学习,平面设计学习,以及操作系统学习

京ICP备14009008号-1@版权所有www.zixuephp.com

网站声明:本站所有视频,教程都由网友上传,站长收集和分享给大家学习使用,如由牵扯版权问题请联系站长邮箱904561283@qq.com

添加评论