摘自织梦CMS的HTTP文件下载类

本文实例讲述了摘自织梦CMS的HTTP文件下载类。分享给大家供大家参考。具体如下:

<?php if(!defined('DEDEINC')) exit("Request Error!");
/**
 * 织梦HTTP下载类
 *
 * @version  $Id: dedehttpdown.class.php 1 11:42 2010年7月6日Z tianya $
 * @package  DedeCMS.Libraries
 * @copyright  Copyright (c) 2007 - 2010, DesDev, Inc.
 * @license  http://help.dedecms.com/usersguide/license.html
 * @link   http://www.dedecms.com
 */
@set_time_limit(0);
class DedeHttpDown
{
 var $m_url = '';
 var $m_urlpath = '';
 var $m_scheme = 'http';
 var $m_host = '';
 var $m_port = '80';
 var $m_user = '';
 var $m_pass = '';
 var $m_path = '/';
 var $m_query = '';
 var $m_fp = '';
 var $m_error = '';
 var $m_httphead = '';
 var $m_html = '';
 var $m_puthead = '';
 var $BaseUrlPath = '';
 var $HomeUrl = '';
 var $reTry = 0;
 var $JumpCount = 0;
 /**
  * 初始化系统
  *
  * @access public
  * @param  string $url 需要下载的地址
  * @return string
  */
 function PrivateInit($url)
 {
  if($url=='') {
   return ;
  }
  $urls = '';
  $urls = @parse_url($url);
  $this->m_url = $url;
  if(is_array($urls))
  {
   $this->m_host = $urls["host"];
   if(!empty($urls["scheme"]))
   {
    $this->m_scheme = $urls["scheme"];
   }
   if(!empty($urls["user"]))
   {
    $this->m_user = $urls["user"];
   }
   if(!empty($urls["pass"]))
   {
    $this->m_pass = $urls["pass"];
   }
   if(!empty($urls["port"]))
   {
    $this->m_port = $urls["port"];
   }
   if(!empty($urls["path"]))
   {
    $this->m_path = $urls["path"];
   }
   $this->m_urlpath = $this->m_path;
   if(!empty($urls["query"]))
   {
    $this->m_query = $urls["query"];
    $this->m_urlpath .= "?".$this->m_query;
   }
   $this->HomeUrl = $urls["host"];
   $this->BaseUrlPath = $this->HomeUrl.$urls["path"];
   $this->BaseUrlPath = preg_replace("/\/([^\/]*)\.(.*)$/","/",$this->BaseUrlPath);
   $this->BaseUrlPath = preg_replace("/\/$/","",$this->BaseUrlPath);
  }
 }
 /**
  * 重设各参数
  *
  * @access public
  * @return void
  */
 function ResetAny()
 {
  $this->m_url = "";
  $this->m_urlpath = "";
  $this->m_scheme = "http";
  $this->m_host = "";
  $this->m_port = "80";
  $this->m_user = "";
  $this->m_pass = "";
  $this->m_path = "/";
  $this->m_query = "";
  $this->m_error = "";
 }
 /**
  * 打开指定网址
  *
  * @access public
  * @param  string $url 地址
  * @param  string $requestType 请求类型
  * @return string
  */
 function OpenUrl($url,$requestType="GET")
 {
  $this->ResetAny();
  $this->JumpCount = 0;
  $this->m_httphead = Array() ;
  $this->m_html = '';
  $this->reTry = 0;
  $this->Close();
  //初始化系统
  $this->PrivateInit($url);
  $this->PrivateStartSession($requestType);
 }
 /**
  * 转到303重定向网址
  *
  * @access public
  * @param  string $url 地址
  * @return string
  */
 function JumpOpenUrl($url)
 {
  $this->ResetAny();
  $this->JumpCount++;
  $this->m_httphead = Array() ;
  $this->m_html = "";
  $this->Close();
  //初始化系统
  $this->PrivateInit($url);
  $this->PrivateStartSession('GET');
 }
 /**
  * 获得某操作错误的原因
  *
  * @access public
  * @return void
  */
 function printError()
 {
  echo "错误信息:".$this->m_error;
  echo "<br/>具体返回头:<br/>";
  foreach($this->m_httphead as $k=>$v){ echo "$k => $v <br/>\r\n"; }
 }
 /**
  * 判别用Get方法发送的头的应答结果是否正确
  *
  * @access public
  * @return bool
  */
 function IsGetOK()
 {
  if( preg_match("/^2/",$this->GetHead("http-state")) )
  {
   return TRUE;
  }
  else
  {
   $this->m_error .= $this->GetHead("http-state")." - ".$this->GetHead("http-describe")."<br/>";
   return FALSE;
  }
 }
 /**
  * 看看返回的网页是否是text类型
  *
  * @access public
  * @return bool
  */
 function IsText()
 {
  if( preg_match("/^2/",$this->GetHead("http-state")) && preg_match("/text|xml/i",$this->GetHead("content-type")) )
  {
   return TRUE;
  }
  else
  {
   $this->m_error .= "内容为非文本类型或网址重定向<br/>";
   return FALSE;
  }
 }
 /**
  * 判断返回的网页是否是特定的类型
  *
  * @access public
  * @param  string $ctype 内容类型
  * @return string
  */
 function IsContentType($ctype)
 {
  if(preg_match("/^2/",$this->GetHead("http-state"))
  && $this->GetHead("content-type")==strtolower($ctype))
  { return TRUE; }
  else
  {
   $this->m_error .= "类型不对 ".$this->GetHead("content-type")."<br/>";
   return FALSE;
  }
 }
 /**
  * 用Http协议下载文件
  *
  * @access public
  * @param  string $savefilename 保存文件名称
  * @return string
  */
 function SaveToBin($savefilename)
 {
  if(!$this->IsGetOK())
  {
   return FALSE;
  }
  if(@feof($this->m_fp))
  {
   $this->m_error = "连接已经关闭!"; return FALSE;
  }
  $fp = fopen($savefilename,"w");
  while(!feof($this->m_fp))
  {
   fwrite($fp, fread($this->m_fp, 1024));
  }
  fclose($this->m_fp);
  fclose($fp);
  return TRUE;
 }
 /**
  * 保存网页内容为Text文件
  *
  * @access public
  * @param  string $savefilename 保存文件名称
  * @return string
  */
 function SaveToText($savefilename)
 {
  if($this->IsText())
  {
   $this->SaveBinFile($savefilename);
  }
  else
  {
   return "";
  }
 }
 /**
  * 用Http协议获得一个网页的内容
  *
  * @access public
  * @return string
  */
 function GetHtml()
 {
  if(!$this->IsText())
  {
   return '';
  }
  if($this->m_html!='')
  {
   return $this->m_html;
  }
  if(!$this->m_fp||@feof($this->m_fp))
  {
   return '';
  }
  while(!feof($this->m_fp))
  {
   $this->m_html .= fgets($this->m_fp,256);
  }
  @fclose($this->m_fp);
  return $this->m_html;
 }
 /**
  * 开始HTTP会话
  *
  * @access public
  * @param  string $requestType 请求类型
  * @return string
  */
 function PrivateStartSession($requestType="GET")
 {
  if(!$this->PrivateOpenHost())
  {
   $this->m_error .= "打开远程主机出错!";
   return FALSE;
  }
  $this->reTry++;
  if($this->GetHead("http-edition")=="HTTP/1.1")
  {
   $httpv = "HTTP/1.1";
  }
  else
  {
   $httpv = "HTTP/1.0";
  }
  $ps = explode('?',$this->m_urlpath);
  $headString = '';
  //发送固定的起始请求头GET、Host信息
  if($requestType=="GET")
  {
   $headString .= "GET ".$this->m_urlpath." $httpv\r\n";
  }
  else
  {
   $headString .= "POST ".$ps[0]." $httpv\r\n";
  }
  $this->m_puthead["Host"] = $this->m_host;
  //发送用户自定义的请求头
  if(!isset($this->m_puthead["Accept"]))
  {
   $this->m_puthead["Accept"] = "*/*";
  }
  if(!isset($this->m_puthead["User-Agent"]))
  {
   $this->m_puthead["User-Agent"] = "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.2)";
  }
  if(!isset($this->m_puthead["Refer"]))
  {
   $this->m_puthead["Refer"] = "http://".$this->m_puthead["Host"];
  }
  foreach($this->m_puthead as $k=>$v)
  {
   $k = trim($k);
   $v = trim($v);
   if($k!=""&&$v!="")
   {
    $headString .= "$k: $v\r\n";
   }
  }
  fputs($this->m_fp, $headString);
  if($requestType=="POST")
  {
   $postdata = "";
   if(count($ps)>1)
   {
    for($i=1;$i<count($ps);$i++)
    {
     $postdata .= $ps[$i];
    }
   }
   else
   {
    $postdata = "OK";
   }
   $plen = strlen($postdata);
   fputs($this->m_fp,"Content-Type: application/x-www-form-urlencoded\r\n");
   fputs($this->m_fp,"Content-Length: $plen\r\n");
  }
  //发送固定的结束请求头
  //HTTP1.1协议必须指定文档结束后关闭链接,否则读取文档时无法使用feof判断结束
  if($httpv=="HTTP/1.1")
  {
   fputs($this->m_fp,"Connection: Close\r\n\r\n");
  }
  else
  {
   fputs($this->m_fp,"\r\n");
  }
  if($requestType=="POST")
  {
   fputs($this->m_fp,$postdata);
  }
  //获取应答头状态信息
  $httpstas = explode(" ",fgets($this->m_fp,256));
  $this->m_httphead["http-edition"] = trim($httpstas[0]);
  $this->m_httphead["http-state"] = trim($httpstas[1]);
  $this->m_httphead["http-describe"] = "";
  for($i=2;$i<count($httpstas);$i++)
  {
   $this->m_httphead["http-describe"] .= " ".trim($httpstas[$i]);
  }
  //获取详细应答头
  while(!feof($this->m_fp))
  {
   $line = trim(fgets($this->m_fp,256));
   if($line == "")
   {
    break;
   }
   $hkey = "";
   $hvalue = "";
   $v = 0;
   for($i=0;$i<strlen($line);$i++)
   {
    if($v==1)
    {
     $hvalue .= $line[$i];
    }
    if($line[$i]==":")
    {
     $v = 1;
    }
    if($v==0)
    {
     $hkey .= $line[$i];
    }
   }
   $hkey = trim($hkey);
   if($hkey!="")
   {
    $this->m_httphead[strtolower($hkey)] = trim($hvalue);
   }
  }
  //如果连接被不正常关闭,重试
  if(feof($this->m_fp))
  {
   if($this->reTry > 10)
   {
    return FALSE;
   }
   $this->PrivateStartSession($requestType);
  }
  //判断是否是3xx开头的应答
  if(preg_match("/^3/",$this->m_httphead["http-state"]))
  {
   if($this->JumpCount > 3)
   {
    return;
   }
   if(isset($this->m_httphead["location"]))
   {
    $newurl = $this->m_httphead["location"];
    if(preg_match("/^http/i",$newurl))
    {
     $this->JumpOpenUrl($newurl);
    }
    else
    {
     $newurl = $this->FillUrl($newurl);
     $this->JumpOpenUrl($newurl);
    }
   }
   else
   {
    $this->m_error = "无法识别的答复!";
   }
  }
 }
 /**
  * 获得一个Http头的值
  *
  * @access public
  * @param  string $headname 头文件名称
  * @return string
  */
 function GetHead($headname)
 {
  $headname = strtolower($headname);
  return isset($this->m_httphead[$headname]) ? $this->m_httphead[$headname] : '';
 }
 /**
  * 设置Http头的值
  *
  * @access public
  * @param  string $skey 键
  * @param  string $svalue 值
  * @return string
  */
 function SetHead($skey,$svalue)
 {
  $this->m_puthead[$skey] = $svalue;
 }
 /**
  * 打开连接
  *
  * @access public
  * @return bool
  */
 function PrivateOpenHost()
 {
  if($this->m_host=="")
  {
   return FALSE;
  }
  $errno = "";
  $errstr = "";
  $this->m_fp = @fsockopen($this->m_host, $this->m_port, $errno, $errstr,10);
  if(!$this->m_fp)
  {
   $this->m_error = $errstr;
   return FALSE;
  }
  else
  {
   return TRUE;
  }
 }
 /**
  * 关闭连接
  *
  * @access public
  * @return void
  */
 function Close()
 {
  @fclose($this->m_fp);
 }
 /**
  * 补全相对网址
  *
  * @access public
  * @param  string $surl 需要不全的地址
  * @return string
  */
 function FillUrl($surl)
 {
  $i = 0;
  $dstr = "";
  $pstr = "";
  $okurl = "";
  $pathStep = 0;
  $surl = trim($surl);
  if($surl=="")
  {
   return "";
  }
  $pos = strpos($surl,"#");
  if($pos>0)
  {
   $surl = substr($surl,0,$pos);
  }
  if($surl[0]=="/")
  {
   $okurl = "http://".$this->HomeUrl.$surl;
  }
  else if($surl[0]==".")
  {
   if(strlen($surl)<=1)
   {
    return "";
   }
   else if($surl[1]=="/")
   {
    $okurl = "http://".$this->BaseUrlPath."/".substr($surl,2,strlen($surl)-2);
   }
   else
   {
    $urls = explode("/",$surl);
    foreach($urls as $u)
    {
     if($u=="..")
     {
      $pathStep++;
     }
     else if($i<count($urls)-1)
     {
      $dstr .= $urls[$i]."/";
     }
     else
     {
      $dstr .= $urls[$i];
     }
     $i++;
    }
    $urls = explode("/",$this->BaseUrlPath);
    if(count($urls) <= $pathStep)
    {
     return "";
    }
    else
    {
     $pstr = "http://";
     for($i=0;$i<count($urls)-$pathStep;$i++)
     {
      $pstr .= $urls[$i]."/";
     }
     $okurl = $pstr.$dstr;
    }
   }
  }
  else
  {
   if(strlen($surl)<7)
   {
    $okurl = "http://".$this->BaseUrlPath."/".$surl;
   }
   else if(strtolower(substr($surl,0,7))=="http://")
   {
    $okurl = $surl;
   }
   else
   {
    $okurl = "http://".$this->BaseUrlPath."/".$surl;
   }
  }
  $okurl = preg_replace("/^(http:\/\/)/i","",$okurl);
  $okurl = preg_replace("/\/{1,}/", "/", $okurl);
  return "http://".$okurl;
 }
}//End Class

希望本文所述对大家的php程序设计有所帮助。

(0)

相关推荐

  • PHP实现远程下载文件到本地

    代码很简单就不多废话了,直接奉上: <?php echo httpcopy("http://www.baidu.com/img/baidu_sylogo1.gif"); function httpcopy($url, $file="", $timeout=60) { $file = empty($file) ? pathinfo($url,PATHINFO_BASENAME) : $file; $dir = pathinfo($file,PATHINFO_DI

  • 一周学会PHP(视频)Http下载

    ftp://ftp.cycu.edu.tw/CNA/Course/2004/0816_0820_PHP/videos/040816_PHP_1.wmvftp://ftp.cycu.edu.tw/CNA/Course/2004/0816_0820_PHP/videos/040817_PHP_2.wmvftp://ftp.cycu.edu.tw/CNA/Course/2004/0816_0820_PHP/videos/040816_PHP_3.wmvftp://ftp.cycu.edu.tw/CNA

  • 发布一个用PHP fsockopen写的HTTP下载的类

    如果支持打开远程内容的选项的话,实际上php用fopen或file_get_contents都能获得一个网页的内容,但是默认的函数有个不足的地方就是无法获取HTTP头,这在一些特殊的应用中很不方便,如,有一个链接: http://www.abc.com/showvd.asp?id=18 假如它返回的是一个图片,用默认函数就很难识别,但如果通过HTTP应答头来判断就简单多了,此外如果对方通过 Refer 来防盗链的话,也是无法获取的,用HTTP类就能完美解决这些问题,而且速度也相差无几. 使用方法

  • php实现简单文件下载的方法

    本文实例讲述了php实现简单文件下载的方法.分享给大家供大家参考.具体如下: 这里介绍的php文件下载代码,只是简单实现了一张图片的下载功能,还不完善,最好是封装到一个类里,或是采用函数调用.感兴趣的朋友可以在此基础上加以完善! php文件下载代码如下: <?php $file_name = "2.jpg";//需要下载的图片 define("SPATH","/php/image/");//存放图片的相对路径 $file_sub_path

  • php控制文件下载速度的方法

    本文实例讲述了php控制文件下载速度的方法.分享给大家供大家参考.具体实现方法如下: <?php /* * set here a limit of downloading rate (e.g. 10.20 Kb/s) */ $download_rate = 10.20; $download_file = 'download-file.zip'; $target_file = 'target-file.zip'; if(file_exists($download_file)){ /* header

  • php实现文件下载代码分享

    简单的文件下载只需要使用HTML的连接标记<a>,并将属性href的URL值指定为下载的文件即可.所示: <a href="http://www.jb51.net/download/book.rar">下载文件</a> 如果通过上面的代码实现文件下载,只能处理一些浏览器不能默认识别的MIME类型文件,例如当访问book.rar文件时,浏览器并没有直接打开,而是弹出一个下载提示框,提示用户"下载"还是"打开"等处

  • 跨浏览器PHP下载文件名中的中文乱码问题解决方法

    本文实例讲述了跨浏览器PHP下载文件名中的中文乱码问题解决方法.分享给大家供大家参考.具体如下: 复制代码 代码如下: <?php $ua = $_SERVER["HTTP_USER_AGENT"]; $filename = "中文 文件名.txt"; $encoded_filename = urlencode($filename); $encoded_filename = str_replace("+", "%20",

  • 使用ThinkPHP自带的Http类下载远程图片到本地的实现代码

    Http类在目录ThinkPHP/Lib/ORG/Net下面.接下来看看是如何调用的. 复制代码 代码如下: <?php import("Com.Buyback.QueryAmazon"); import("ORG.Net.Http"); class Image { public static function getImage($isbn) { $bookInformModel = D("bookinform"); $result = $

  • php实现的支持断点续传的文件下载类

    本文实例讲述了php实现的支持断点续传的文件下载类及其用法,是非常实用的技巧.分享给大家供大家参考.具体方法如下: 通常来说,php支持断点续传,主要依靠HTTP协议中 header HTTP_RANGE实现. HTTP断点续传原理: Http头 Range.Content-Range() HTTP头中一般断点下载时才用到Range和Content-Range实体头, Range用户请求头中,指定第一个字节的位置和最后一个字节的位置,如(Range:200-300) Content-Range用

  • 摘自织梦CMS的HTTP文件下载类

    本文实例讲述了摘自织梦CMS的HTTP文件下载类.分享给大家供大家参考.具体如下: <?php if(!defined('DEDEINC')) exit("Request Error!"); /** * 织梦HTTP下载类 * * @version $Id: dedehttpdown.class.php 1 11:42 2010年7月6日Z tianya $ * @package DedeCMS.Libraries * @copyright Copyright (c) 2007

  • 摘自织梦CMS中的图片处理类

    本文实例讲述了摘自织梦CMS中的图片处理类.分享给大家供大家参考.具体如下: <?php if(!defined('DEDEINC')) exit('dedecms'); /** * 图像处理类 * * @version $Id: image.class.php 1 18:10 2010年7月5日Z tianya $ * @package DedeCMS.Libraries * @copyright Copyright (c) 2007 - 2010, DesDev, Inc. * @licen

  • 织梦模板标记简介

    在了解DedeCms的模板代码之前,了解一下织梦模板引擎的知识是非常有意义的.织梦模板引擎是一种使用XML名字空间形式的模板解析器,使用织梦解析器解析模板的最大好处是可以轻松的制定标记的属性,感觉上就像在用HTML一样,使模板代码十分直观灵活,新版的织梦模板引擎不单能实现模板的解析还能分析模板里错误的标记. 1.织梦模板引擎的代码样式有如下几种形式: {dede:标记名称 属性='值'/} {dede:标记名称 属性='值'}{/dede:标记名称} {dede:标记名称 属性='值'}自定义样

  • 织梦sitemap地图实时推送给百度的教程

    在之前,织梦有一套自己主动ping百度的插件,但是后来用不了了,最后百度推出了实时推送链接地址到百度,这样要比sitemap方便好用多了,而且还能保证文章的原创,下面我通过查阅相关资料,根据百度的接口写了一篇sitemap地图实时推送给百度的处理办法,分享给大家. 关于织梦的百度实时推送我写了两种方法,大家可以自行选择: 1.手动创建一个文件,每天访问这个文件就可以把当天的全部文章推送到百度搜索引擎. 在根目录下面创建一个tuisong.php  访问后会返回百度接口结果 <?php requi

  • 基于php的CMS中展示文章类实例分析

    本文实例讲述了基于php的CMS中展示文章类.分享给大家供大家参考.具体分析如下: <?php /*********************************************** //实例: include("config.inc.php"); //数据库连接文件 $info = new sys_function; $test = new show_article; $test->set_sql("SELECT `id`,`title`,`datea

  • PowerShell小技巧之实现文件下载(类wget)

    对Linux熟悉的读者可能会对Linux通过wget下载文件有印象,这个工具功能很强大,在.NET环境下提到下载文件大多数人熟悉的是通过System.Net.WebClient进行下载,这个程序集能实现下载的功能,但是有缺陷,如果碰上类似于-/scripts/?dl=417这类的下载链接将无法正确识别文件名,下载的文件通常会被命名为dl=417这样古怪的名字,其实对应的文件名是在访问这个链接返回结果的HTTP头中包含的.事实上微软也提供了避免这些缺陷的程序集System.Net.HttpWebR

  • PHP文件下载类

    复制代码 代码如下: <?    //====================================================    //   使用范例:    // $download=new download('php,exe,html',false);    //  if(!$download->downloadfile($filename))    //  {    //    echo $download->geterrormsg();    //  }    

  • PHP实现删除非站内外部链接实例代码

    一般在做网站系统的时候,出于优化等因素的考虑需要再添加文章的时候删除掉不是本站的链接,对于这一要求可以通过让PHP处理下文章内容,来达到文章外部链接的自动删除的效果. 本实例代码主要参考织梦CMS内容管理系统的外链删除方法. 复制代码 代码如下: /** *  删除非站内链接 * * @access    public * @param     string  $body  内容 * @param     array  $allow_urls  允许的超链接 * @return    strin

随机推荐