php专区

 首页 > php专区 > PHP应用 > 常用功能 > php用Curl伪造客户端源IP - php高级应用

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

分享到:
【字体:
导读:
          在网上找了很多种用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. $ch = curl_init(); 
  2. curl_setopt($ch, CURLOPT_URL, "http://localhost/index.php"); 
  3. curl_setopt($ch, CURLOPT_HTTPHEADER, array('X-FORWARDED-FOR:8.8.8.8''CLIENT-IP:8.8.8.8'));  
  4. //构造IP 
  5. curl_setopt($ch, CURLOPT_REFERER, "http://www.phpfensi.com/ ");   //构造来路 
  6. curl_setopt($ch, CURLOPT_HEADER, 1); 
  7. $out = curl_exec($ch); 
  8. curl_close($ch); 

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

  1. function getClientIp() { 
  2.     if (!emptyempty($_SERVER["HTTP_CLIENT_IP"])) 
  3.         $ip = $_SERVER["HTTP_CLIENT_IP"]; 
  4.     else if (!emptyempty($_SERVER["HTTP_X_FORWARDED_FOR"])) 
  5.         $ip = $_SERVER["HTTP_X_FORWARDED_FOR"]; 
  6.     else if (!emptyempty($_SERVER["REMOTE_ADDR"])) 
  7.         $ip = $_SERVER["REMOTE_ADDR"]; 
  8.     else 
  9.         $ip = "err"
  10.     return $ip
  11. echo "IP: " . getClientIp() . ""
  12. echo "referer: " . $_SERVER["HTTP_REFERER"]; 
  13. echo "IP: " . getClientIp() . ""
  14. 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 ajax.$post实现攒,顶,踩的功能 - php...
php ajax.$post实现攒,顶,踩的功能 攒,顶,踩功能主要用于评论中这里我们来做一个简单基于jquery ajax与php的mysql实现的攒,顶,踩功能。 php应用越来越多,也越来越广泛,为了增加网站的丰富多彩,从而出现了很多新的技术。ajax是现代网站中不能缺少的一项技术,他可以异步刷新数据,而实现...
php 通过curl post发送json数据实例 - ph...
php 通过curl post发送json数据实例 利用php curl发送json数据与curl post其它数据是一样的,下面我来给大家总结几个关于curl post发送json数据实例,希望能加深各位对curl post json数据的理解吧。 例1代码如下: $data = array("name" => "Hagrid", "age" => "36");      ...
  •         php迷,一个php技术的分享社区,专属您自己的技术摘抄本、收藏夹。
  • 在这里……