用户名:
密 码: 记住
您当前的位置:首页 > 网络编程 > php教程

PHP get_headers函数判断远程文件是否存在

时间:2015-01-23  来源:西部数据  作者:西部数据

以前我有讲过程关于php判断远程文件是否存在的文章,那里都介绍利用fopen,sockt,curl函数来实现检查远程文件是否存在了,下面我再介绍利用 get_headers来检查远程文件是否存在,有需要了解的朋友可参考.

先来简单了解get_headers()函数

get_headers() 返回一个数组m包含有服务器响应一个 HTTP 请求所发送的标头。

get_headers:发送服务器响应HTTP请求

get_headers(字符串url[链接格式])

get_headers()以数组的形式返回服务器HTTP请求m如果执行失败,将返回FALSE和一个错误的水平E_WARNING》,

可选参数设置为1,get_headers()能分析系统的响应速度和集数组中的键,

注意:使用该函数需要把 php.ini里面的allow_url_fopen = On,才能使用

例,代码如下:

  1. <?php 
  2. $url = 'http://www.phpfensi.com'
  3. print_r(get_headers($url)); 
  4. print_r(get_headers($url, 1)); 
  5. ?> 
  6. 返回值 
  7. Array 
  8.     [0] => HTTP/1.1 200 OK 
  9.     [1] => Date: Sat, 29 May 2004 12:28:13 GMT 
  10.     [2] => Server: Apache/1.3.27 (Unix)  (Red-Hat/Linux) 
  11.     [3] => Last-Modified: Wed, 08 Jan 2003 23:11:55 GMT 
  12.     [4] => ETag: "3f80f-1b6-3e1cb03b" 
  13.     [5] => Accept-Ranges: bytes 
  14.     [6] => Content-Length: 438 
  15.     [7] => Connection: close 
  16.     [8] => Content-Type: text/html 
  17. Array 
  18.     [0] => HTTP/1.1 200 OK 
  19.     [Date] => Sat, 29 May 2004 12:28:14 GMT 
  20.     [Server] => Apache/1.3.27 (Unix)  (Red-Hat/Linux) 
  21.     [Last-Modified] => Wed, 08 Jan 2003 23:11:55 GMT 
  22.     [ETag] => "3f80f-1b6-3e1cb03b" 
  23.     [Accept-Ranges] => bytes 
  24.     [Content-Length] => 438 
  25.     [Connection] => close 
  26.     [Content-Type] => text/html 

例,代码如下:

  1. //判断远程文件是否存在   
  2. function remote_file_exists($url) {   
  3.         $executeTime = ini_get('max_execution_time');   
  4.         ini_set('max_execution_time', 0);   
  5.         $headers = @get_headers($url);   
  6.         ini_set('max_execution_time'$executeTime);   
  7.         if ($headers) {   
  8.             $head = explode(' '$headers[0]);   
  9.             if ( !emptyempty($head[1]) && intval($head[1]) < 400) return true;   
  10.         }   
  11.         return false;   
  12.  } 

例2,排除重定向的例子,代码如下:

  1. <?php  
  2. /** 
  3.  * Fetches all the real headers sent by the server in response to a HTTP request without redirects 
  4.  * 获取不包含重定向的报头 
  5.  */  
  6.      
  7. function get_real_headers($url,$format=0,$follow_redirect=0) {  
  8.   if (!$follow_redirect) {  
  9.     //set new default options  
  10.     $opts = array('http' =>  
  11.         array('max_redirects'=>1,'ignore_errors'=>1)  
  12.     );  
  13.     stream_context_get_default($opts);  
  14.   }  
  15.   //get headers  
  16.     $headers=get_headers($url,$format);  
  17.     //restore default options  
  18.   if (isset($opts)) {  
  19.     $opts = array('http' =>  
  20.         array('max_redirects'=>20,'ignore_errors'=>0)  
  21.     ); //开源软件:phpfensi.com 
  22.     stream_context_get_default($opts);  
  23.   }  
  24.   //return  
  25.     return $headers;  
  26. }  
  27. ?>
来顶一下
返回首页
返回首页
推荐资讯
WiFi太不安全:7岁女孩11分钟内入侵公共网络 WiFi太不安全:7岁女孩11分钟内入侵近期刚刚发布研究说WiFi网络能获得人们手机里多少私人信息,
不服跑个分?人工智能也出现“刷分”乱象 不服跑个分?人工智能也出现“刷分2014年,人工智能领域突然爆发,成为了科研和科技创业的热门
相关文章
    无相关信息
栏目更新
栏目热门