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页⾯,基础解决⽅法就是判断来路来限制⾮调⽤访问:
$refererUrl = parse_url($_SERVER[‘HTTP_REFERER']);
$host = $refererUrl[‘host'];
$host的值即为来路的⽹址(www.httple)。
获取到了来路的⽹址之后,我们就可以通过这个⽹址来限制访问该页⾯的权限了。代码如下:
if(!isset($_SERVER[‘HTTP_REFERER']) || $referurl[‘host'] !=”www.httple”) {
header(“location: /”); //如果没有来路,或者来路不是本站,跳转到⾸页。
exit;
}
把这⾏代码放到json数据页⾯的最上⽅,就能简单解决该问题。
该处理⽅法的缺陷:可通过伪造来路获取到该页⾯的正常数据。
相关代码
获取来路Url 的⽅法,主要⽤到服务器变量中HTTP_REFERER函数的使⽤,代码贴上:
function get_referer(){
$url = $_SERVER["HTTP_REFERER"]; //获取完整的来路URL
$str = str_replace("","",$url); //去掉
php中header是什么意思$strdomain = explode("/",$str); // 以“/”分开成数组
$domain = $strdomain[0]; //取第⼀个“/”以前的字符
return $domain;
}
//对于百度、⾕歌搜索引擎来路判断
function get_seo(){
$s = 0;
if(strstr(get_referer(),'baidu')){
$s = 1;
}
else if(strstr(get_referer(),'google.hk')){
$s = 1;
}
return $se;
}
php⽹站获取来路Url 的⽅法,主要⽤到服务器变量中HTTP_REFERER函数的使⽤,代码贴上:
function get_referer(){
$url = $_SERVER["HTTP_REFERER"]; //获取完整的来路URL
$str = str_replace(“”,””,$url); //去掉
$strdomain = explode(“/”,$str); // 以“/”分开成数组
$domain = $strdomain[0]; //取第⼀个“/”以前的字符
return $domain;
}
/
/对于百度、⾕歌搜索引擎来路判断
function get_seo(){
$s = 0;
if(strstr(get_referer(),'baidu')){
$s = 1;
}
else if(strstr(get_referer(),'google.hk')){
$s = 1;
}
return $se;
}
在处理⼀个表单的时候,不得不考虑到⽤户静态提交的可能,discuz 已经根据formhash来判断
这⾥我⽤另⼀种⽅式来处理判断页⾯来路,当然这种⽅法也能够被伪造HTTP_REFERER来路
第⼆部分是解决了 PHP中header('location:  跳转页⾯后下⼀页⽆法获取HTTP_REFERER,这⾥只能在页⾯加个链接然后⽤js 模拟点击链接,这样下⼀页肯定会收到HTTP_REFERER的。Keyword:ElementById('gourl').click();
到此这篇关于php获取referer防⾮法访问的⽂章就介绍到这了,更多相关php放置⾮法访问内容请搜索以前的⽂章或继续浏览下⾯的相关⽂章希望⼤家以后多多⽀持!

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。