1. <?<a href="http://lib.csdn.net/base/php" class='replace_word' title="PHP知识库" target='_blank' style='color:#df3434; font-weight:bold;'>PHP</a>  
  2.   session_start();  
  3.   if(!isset($_SESSION['id'])or !isset($_SESSION['member'])){  
  4. echo "<mce:script type="text/<a href="http://lib.csdn.net/base/javascript" class='replace_word' title="JavaScript知识库" target='_blank' style='color:#df3434; font-weight:bold;'>JavaScript</a>"><!--  
  5. alert('您没有登录或超时');history.back;  
  6. // --></mce:script>";//验证session  
  7. exit();  
  8. }  
  9. $ref=$_SERVER['HTTP_REFERER'];  
  10. if($ref==''){  
  11. echo '对不起,不允许从地址栏访问';  
  12. }else{  
  13. $url=parse_url($ref);  
  14.   if($url[host]!='127.0.0.1'&& $url[host]!='localhost'){  
  15.   echo '不允许盗链';  
  16.   exit();  
  17.   }  
  18. }  
  19. ?>  

 

php手册中的官方解释:
"HTTP_REFERER"

链接到当前页面的前一页面的 URL 地址。不是所有的用户代理(浏览器)都会设置这个变量,而且有的还可以手工修改 HTTP_REFERER。因此,这个变量不总是真实正确的。

总结:只有点击超链接(即<A href=...>) 打开的页面才有HTTP_REFERER环境变量, 其它如 window.open()、 window.location=...、window.showModelessDialog()等打开的窗口都没有HTTP_REFERER 环境变量。
posted on 2017-07-11 10:17  飘渺的悠远  阅读(1096)  评论(0编辑  收藏  举报