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

发现一个关于浏览器兼容的问题,当用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 表单提交的请求,下面是根据网上的资料总结的一个方法:

Js代码   收藏代码
  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. }  
  10. else window.location = url;  
  11. }  
  12.   
  13. var url=”http://justcoding.iteye.com”;  
  14. referURL(url);  
  15. </script>  

 

 

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

 

此方法在IE, Firefox, Safari , Chrome 测试通过

 

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

 

referer.php

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

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. }  
  13. echo "IP: " . getClientIp() . "<br>";  
  14. echo "referer: " . $_SERVER["HTTP_REFERER"];  

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值