php专区

 首页 > php专区 > PHP高级 > 引用 > PHP中如何防止跨域调用接口

PHP中如何防止跨域调用接口

分享到:
【字体:
导读:
         摘要:用过ajax的童鞋就知道ajax可以跨域触发某个接口,但是由此引起一个任何域都可以调用的问题,这时候就要考虑用到防盗链技术...

PHP中如何防止跨域调用接口

用过ajax的童鞋就知道ajax可以跨域触发某个接口,但是由此引起一个任何域都可以调用的问题,这时候就要考虑用到防盗链技术了,在PHP中$_SERVER["HTTP_REFERER"],$_SERVER["HTTP_REFERER"]里放置的是链接到本页面的上一个页面的URL,假如你是直接进来的话,$_SERVER["HTTP_REFERER"]是没有值的。下面以一个简单的实例介绍一下,PHP如何防伪造提交数据:

非9streets.cn调用的接口为拒绝访问:

 

PHP代码
  1. //判断refer防止别的域调  
  2. $refer = $_SERVER['HTTP_REFERER'];  
  3. if($refer){  
  4.     $url = parse_url($refer);  
  5.     if ($url['host'] != '9streets.cn') {  
  6.          exit('拒绝访问!');  
  7.     }   
  8. }  

允许在子域名间调用的方法

 

PHP代码
  1. //判断refer防止别的域调用  
  2. $refer = $_SERVER['HTTP_REFERER'];  
  3. if($refer){  
  4.     $url = parse_url($refer);  
  5.     $t = explode('.',$url['host']);  
  6.     $l = count($t);  
  7.     $domainStr = $t[$l-2].'.'.$t[$l-1];  
  8.     if ($domainStr != '9streets.cn') {  
  9.      exit('拒绝访问!');  
  10.     }   
  11. }  
PHP中如何防止跨域调用接口
分享到:
再谈include和require区别
再谈include和require区别 include()和require()语句的不同在于它们如何处理错误。使用require ()调用文件错误时,将会停止整个程序,调用include()遇到相同的错误,则会生成警告并停止执行包含文件,跳出调用代码然后继续执行。前者行为更加激烈火,故require()和require_once()用于包含库文件时更加安全,而include ()和...
PHP两种include加载文件方式效率比较
PHP两种include加载文件方式效率比较 继续完善“X计划”的核心部分,核心嘛,就要加载必须的文件,尝试了两种方法,发现效率是不同的,分享一下吧~先来说说两种方式: 1)定义一个字符串变量,里面保存要加载的文件列表。然后foreach加载。 $a = '/a.class.php;/Util/b.class.php;/Util/c.class.php'; $b = ...
  •         php迷,一个php技术的分享社区,专属您自己的技术摘抄本、收藏夹。
  • 在这里……