>  기사  >  백엔드 개발  >  判断访问来源的疑问

判断访问来源的疑问

WBOY
WBOY원래의
2016-06-23 14:10:421062검색

假设我的站点是 a.com 有图片a.com/123.png

b.com 使用该图片的时候 http_referer 是?

然后直接在地址栏输入a.com/123.png http_referer 是b.com

我想问的是怎么判断图片是其它站被引用还是用户直接访问?


回复讨论(解决方案)

Request.ServerVariables["HTTP_REFERER"]
Request.ServerVariables["HTTP_REFERER"].ToString().Contains(Request.ServerVariables["HTTP_HOST"].ToString())

在外链点进去的时候 HTTP_REFERER也带着这个网站的主机地址呢
加个IF语句来判断。然后tostring解析到地址,就可以用计数器判断了

直接浏览器输入 HTTP_REFERER 为空
从页面链接过来 HTTP_REFERER 为那个页面的url

但是需要注意的是,所有有 HTTP_ 前缀的变量都是访问方提供的,可靠性极低

你只能靠HTTP_REFERER来判断,虽然这个不是很靠谱可以伪造。

Request.ServerVariables["HTTP_REFERER"]
Request.ServerVariables["HTTP_REFERER"].ToString().Contains(Request.ServerVariables["HTTP_HOST"].ToString())

在外链点进去的时候 HTTP_REFERER也带着这个网站的主机地址呢
加个IF语句来判断。然后tostring解析到地址,就可以用计数器判断了

有没有PHP版本的大侠

$_SERVER['HTTP_REFERER']里面
至于里面参数好像有点多。打出来慢慢看。

楼主说的这个问题就是盗链啊。

 header("content-type:text/html; charset=utf-8");
 if(isset($_SERVER['HTTP_REFERER'][
])){
 
//判断$_SERVER['HTTP_REFERER'是不是以http://localhost/test/为开头的
//如果是,则说明是本网站,如果不是,则说明不是本网站,
if(strpos($_SERVER['HTTP_REFERER'],"http://localhost/test/")==0){
echo '这是本站访问';

}else{
//跳转到警告页面
header('Location:warning.php');
}
 
 }else{
//跳转到警告页面
header('Location:warning.php');
 }

以上这段代码是我自己写的一段反盗链的代码。你的问题,一看这段代码就能够解决。在传智播客韩顺平php系列视频中的第84讲就讲到了这个反盗链的问题。可以更清楚的了解了。

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.