>백엔드 개발 >PHP 튜토리얼 >PHP中的$_SERVER["HTTP_REFERER"]用法浅谈

PHP中的$_SERVER["HTTP_REFERER"]用法浅谈

WBOY
WBOY원래의
2016-06-23 13:42:57884검색

大家知道$_SESSION['HTTP_REFERER']可以获取当前链接的上一个连接的来源地址,即链接到当前页面的前一页面的 URL 地址,可以做到防盗链作用,只有点击超链接(即) 打开的页面才有HTTP_REFERER环境变量, 其它如 window.open()、 window.location=...、window.showModelessDialog()等打开的窗口都没有HTTP_REFERER 环境变量。

写个函数吧 简单的可以、起到防盗链作用

  function   checkurl(){   

  //如果直接从浏览器连接到页面,就连接到登陆窗口   

  //echo   "referer:".$_SESSION['HTTP_REFERER'];   

  if(!isset($_SESSION['HTTP_REFERER']))   {   

  header("location:   login");   

  exit;   

  }   

  $urlar   =   parse_url($_SESSION['HTTP_REFERER']);   

  //如果页面的域名不是服务器域名,就连接到登陆窗口   

  if($_SERVER['HTTP_HOST']   !=   $urlar["host"]   &&   $urlar["host"]   !=   "202.102.110.204"   &&   $urlar["host"]   !=   "http://blog.163.com/fantasy_lxh/")   {   

  header("location:   login.php");   

  exit;   

  }     

  }   

checkurl()

?>


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