·您当前的位置:首页 > 技术教程 > JavaScript >

[PHP]IE和FF:获取Referer的JS和PHP方法PHP利用curl伪造IP和来路

时间:2014-07-20 20:33酷播
[PHP]IE和FF:获取Referer的JS和PHP方法PHP利用curl伪造IP和来路,Firefox 可以获取到到HTTP_REFERER页面,但是在IE中这一项为空,后来查了一些相关资料

发现一个关于浏览器兼容的问题,当用JS 执行代码 window.location.href=”http://justcoding.iteye.com” 来进行跳转的时候,Firefox 可以获取到到HTTP_REFERER页面,但是在IE中这一项为空,后来查了一些相关资料,发现在IE 中通过 window.location.href 或者是 是无法获取HTTP_REFERER, 真是搞不懂 IE 的浏览器,很多浏览器运行的很好的东西,它就是不支持,最后没有办法,只能PHP伪造来源HTTP_REFERER的方法或者用JS来伪造。

IE可以识别的 HTTP_REFERER 提交是通过click 触发的事件或者是 Form 表单提交的请求,下面是根据网上的资料总结的一个方法:

  1. <script> 
  2. function referURL(url){ 
  3. var isIe=(document.all)?true:false; 
  4. if(isIe) { 
  5. var linka = document.createElement(‘a’); 
  6. linka.href=url
  7. document.body.appendChild(linka); 
  8. linka.click(); 
  9. else window.location = url
  10.  
  11. var url=”http://justcoding.iteye.com”; 
  12. referURL(url); 
  13. </script> 

这个方法先是用 document.all 来判断当前的浏览器是否是IE, 如果是的话就生成一个link,然后自动执行 onclick 事件,如果不是的话就用JS 跳转。这样在处理页面就可以得到 HTTP_REFERER 了 ,此方法在IE, Firefox, Safari , Chrome 测试通过

2. PHP利用curl伪造IP和来路HTTP Referrer

referer.php

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

ip.php

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

 

热门文章推荐

请稍候...

保利威视云平台-轻松实现点播直播视频应用

酷播云数据统计分析跨平台播放器