完美兼容各大浏览器获取HTTP_REFERER方法总结

作者:hebedich 时间:2024-04-22 13:04:24 

后来查了一些相关资料,发现在IE 中通过 window.location.href 或者是 是无法获取HTTP_REFERER, 真是搞不懂 IE 的浏览器,很多浏览器运行的很好的东西,它就是不支持,最后没有办法,只能PHP伪造来源HTTP_REFERER的方法或者用JS来伪造。

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


<script>
function referURL(url){
var isIe=(document.all)?true:false;
if(isIe) {
var linka = document.createElement(‘a');
linka.href=url;
document.body.appendChild(linka);
linka.click();
}
else window.location = url;
}

var url=”https://www.jb51.net”;
referURL(url);
</script>

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

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

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

referer.php


<?php
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, "http://mydomain.com/ip.php");
curl_setopt($ch, CURLOPT_HTTPHEADER, array('X-FORWARDED-FOR:8.8.8.8', 'CLIENT-IP:8.8.8.8')); //构造IP
curl_setopt($ch, CURLOPT_REFERER, "https://www.jb51.net/ ");  //构造来路
curl_setopt($ch, CURLOPT_HEADER, 1);
$out = curl_exec($ch);
curl_close($ch);

echo $out;

ip.php


<?php
function getClientIp() {
if (!empty($_SERVER["HTTP_CLIENT_IP"]))
$ip = $_SERVER["HTTP_CLIENT_IP"];
else if (!empty($_SERVER["HTTP_X_FORWARDED_FOR"]))
$ip = $_SERVER["HTTP_X_FORWARDED_FOR"];
else if (!empty($_SERVER["REMOTE_ADDR"]))
$ip = $_SERVER["REMOTE_ADDR"];
else
$ip = "err";
return $ip;
}
echo "IP: " . getClientIp() . "<br>";
echo "referer: " . $_SERVER["HTTP_REFERER"];
标签:HTTP,REFERER
0
投稿

猜你喜欢

  • Python跑循环时内存泄露的解决方法

    2023-07-18 08:18:22
  • Python教程使用Chord包实现炫彩弦图示例

    2022-10-10 17:50:14
  • 使用watch监听对象里面值的变化

    2024-06-07 15:22:10
  • python+opencv实现摄像头调用的方法

    2022-08-13 02:29:46
  • Python 游戏大作炫酷机甲闯关游戏爆肝数千行代码实现案例进阶

    2023-06-03 17:37:26
  • mssql server 存储过程里,bulk insert table from '路径+文件',路径固定,文件名不固定的实现方法

    2024-01-13 17:39:18
  • 伪静态下不能使用FCKeditor的解决方法

    2023-02-03 06:54:20
  • PHP session有效期session.gc_maxlifetime

    2023-11-14 17:01:45
  • 解决Python2.7中IDLE启动没有反应的问题

    2022-10-17 17:43:57
  • Transactional replication(事务复制)详解之如何跳过一个事务

    2024-01-19 15:41:16
  • JS+php后台实现文件上传功能详解

    2024-04-27 15:22:28
  • python热力图实现简单方法

    2023-10-28 06:14:41
  • 详解在OpenCV中实现的图像标注技术

    2023-12-01 11:54:34
  • php+mysqli数据库连接的两种方式

    2023-10-08 22:15:16
  • python使用多线程不断刷新网页的方法

    2022-10-03 09:19:26
  • Mysql中LAST_INSERT_ID()的函数使用详解

    2024-01-16 06:50:32
  • Django查询数据库的性能优化示例代码

    2024-01-22 22:18:48
  • asp如何实现强制登录注册?

    2010-05-24 18:13:00
  • python爬虫beautiful soup的使用方式

    2023-05-17 08:13:22
  • python删除服务器文件代码示例

    2023-07-26 15:44:08
  • asp之家 网络编程 m.aspxhome.com