如何用PHP获取referer判断来路防止非法访问

本篇文章给大家介绍如何用PHP获取referer判断来路防止非法访问?有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。

如何用PHP获取referer判断来路防止非法访问

下载页面down.php 的php代码 现在我发现,用迅雷,谷歌浏览器直接打开,就能输出下载文件,一点不起防盗链作用。 现在我想,只允许在我自己站上连接过来的可以直接使用,别的的站过来的,和直接输入这个地址的,跳转到copy.htm页上去。

PHP中的 $_SERVER["HTTP_REFERER"] 预定义服务器变量可以判断来路。

$_SESSION['HTTP_REFERER']可以获取当前链接的上一个连接的来源地址,即链接到当前页面的前一页面的 URL 地址。
一般用于判断浏览者是从哪里点击链接跳到本页面的,即所说的来路,还可以通过判断来路来防止盗链。
例如:

<?php
 $url_array = parse_url($_SESSION['HTTP_REFERER']); 
 //如果页面的域名不是服务器域名,就连接到登陆窗口 
 if($_SERVER['HTTP_HOST'] != $url_array["host"]) { 
 header("location: login.php"); 
 exit; 
 } 
 ?>

登录后复制

近期有个项目需要用到防止用户非法访问某json页面,基础解决方法就是判断来路来限制非调用访问:

$_SERVER[‘HTTP_REFERER’]:来路链接,可能带尾巴(如: 
可以通过php内置函数parse_url()来获取到当前网址(www.httple.net),即:
$refererUrl = parse_url($_SERVER[‘HTTP_REFERER’]);
$host = $refererUrl[‘host’];
$host的值即为来路的网址(www.httple.net)。
获取到了来路的网址之后,我们就可以通过这个网址来限制访问该页面的权限了。代码如下:
if(!isset($_SERVER[‘HTTP_REFERER’]) || $referurl[‘host’] !=”www.httple.net”) { header(“location: /”); 
//如果没有来路,或者来路不是本站,跳转到首页。 exit; }

登录后复制

把这行代码放到json数据页面的最上方,就能简单解决该问题。

该处理方法的缺陷:可通过伪造来路获取到该页面的正常数据。

相关代码

获取来路Url 的方法,主要用到服务器变量中HTTP_REFERER函数的使用,代码贴上:

function get_referer(){   
$url = $_SERVER["HTTP_REFERER"]; //获取完整的来路URL   
$str = str_replace("http://","",$url); //去掉http://   
$strdomain = explode("/",$str); // 以“/”分开成数组   
$domain = $strdomain[0]; //取第一个“/”以前的字符  
return $domain;  
}   

//对于百度、谷歌搜索引擎来路判断   
function get_seo(){  
$s = 0;   
if(strstr(get_referer(),'baidu.com')){   
$s = 1;   
}   
else if(strstr(get_referer(),'google.com.hk')){   
$s = 1;   
}   
return $se;    
}

登录后复制

php网站 获取来路Url 的方法,主要用到服务器变量中HTTP_REFERER函数的使用,代码贴上:

在处理一个表单的时候,不得不考虑到用户静态提交的可能,discuz 已经根据formhash来判断

这里我用另一种方式来处理 判断页面来路,当然这种方法也能够被伪造HTTP_REFERER来路

第二部分是解决了 PHP中header('location: 跳转页面后 下一页无法获取HTTP_REFERER,这里只能在页面加个链接 然后用js 模拟点击链接,这样下一页肯定会收到HTTP_REFERER的。Keyword:document.getElementById('gourl'😉.click();

关于如何用PHP获取referer判断来路防止非法访问的文章就分享到这,如果对你有帮助欢迎继续关注我们哦

本文来自投稿,不代表科技代码立场,如若转载,请注明出处https://www.cwhello.com/244191.html

如有侵犯您的合法权益请发邮件951076433@qq.com联系删除

(0)
上一篇 2023年3月29日 08:43
下一篇 2023年3月29日 23:09

相关推荐

  • 5种PHP定义数组的方法

    下面由PHP教程栏目给大家介绍5种PHP定义数组的方法,希望对需要的朋友有所帮助!定义数组的5种方法<?php echo "<hr>"; //定义数组的多种方法 //方法一 $array=array('orange','...

    2022年6月27日
    0140
  • 打造稳定和高质量的PHP直播功能。

    PHP是一种开放源代码的服务器端编程语言,适用于web开发。随着网络直播的迅速发展,越来越多的网站开始开发直播功能来吸引更多用户。要实现一个稳定和高质量的PHP直播功能,需要经过以下步骤。第一步——确定需求在...

    2023年5月28日
    00
  • php基本语法形式及变量规则

    基本语法形式 区分大小写 主要是指变量名区分大小写 常量通常也区分,但常量也可以自己设定为不区分(不推荐) 但函数名不区分 而系统中使用的关键字也不区分大小写,比如if, else, for 语句结束符,用分号 一...

    2017年11月1日
    0197
  • PHP与BI工具的集成

    随着数据分析和商业智能(BI)的普及,越来越多的企业开始使用BI工具来帮助他们更好地理解和管理企业数据。PHP是一种广泛使用的Web开发语言,在企业中也非常常见。因此,将PHP和BI工具集成在一起可以带来许多好处...

    2023年5月19日
    01
  • 重蔚自留地php学习第三十六天——PHP的魔术方法

    魔术方法一览 说明 魔术方法都是系统提供,程序员使用即可. 所有的魔术方法,前面都是以 __ 开头的 _是两个下划线. 我们在自定义函数时,就不要使用 __开头了. 魔术方法是在满足某个条件(一会一个一个的说明)时,...

    2018年5月15日 PHP自学教程
    0180
  • PHP8中的新函数:array_key_last()的多种用途。

    随着PHP8的发布,我们迎来了许多新的特性和函数,其中一个重要的新函数就是array_key_last()。这个函数的作用是返回一个数组的最后一个键名。在本文中,我们将介绍array_key_last()的多种用途。第一种用途:删除...

    2023年5月21日
    02
  • 微信小程序中PHP开发的常用类库介绍。

    随着移动互联网的不断发展,各类App的使用越来越普遍,规模也越来越大。微信小程序作为一种新兴的应用形态,受到越来越多开发者的青睐。而PHP开发的小程序也成为了一种趋势。在这种趋势下,PHP常用类库的使用也变...

    2023年6月3日
    01
  • PHP8中的数组函数:array_reduce()的多种应用示例。

    PHP8中的数组函数:array_reduce()的多种应用示例在PHP中,数组是一种非常重要的数据类型,它可以存储多个值,并且可以使用各种数组函数进行操作和处理。其中,array_reduce()函数是一种非常有用的函数,它可以将...

    2023年5月21日
    00

联系我们

QQ:951076433

在线咨询:点击这里给我发消息邮件:951076433@qq.com工作时间:周一至周五,9:30-18:30,节假日休息