《PHP教程:摘自織夢(mèng)CMS的HTTP文件下載類(lèi)》要點(diǎn):
本文介紹了PHP教程:摘自織夢(mèng)CMS的HTTP文件下載類(lèi),希望對(duì)您有用。如果有疑問(wèn),可以聯(lián)系我們。
PHP應(yīng)用本文實(shí)例講述了摘自織夢(mèng)CMS的HTTP文件下載類(lèi).分享給大家供大家參考.具體如下:
PHP應(yīng)用
<?php if(!defined('DEDEINC')) exit("Request Error!");
/**
* 織夢(mèng)HTTP下載類(lèi)
*
* @version $Id: dedehttpdown.class.php 1 11:42 2010年7月6日Z(yǔ) 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;
/**
* 初始化系統(tǒng)
*
* @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);
}
}
/**
* 重設(shè)各參數(shù)
*
* @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 = "";
}
/**
* 打開(kāi)指定網(wǎng)址
*
* @access public
* @param string $url 地址
* @param string $requestType 哀求類(lèi)型
* @return string
*/
function OpenUrl($url,$requestType="GET")
{
$this->ResetAny();
$this->JumpCount = 0;
$this->m_httphead = Array() ;
$this->m_html = '';
$this->reTry = 0;
$this->Close();
//初始化系統(tǒng)
$this->PrivateInit($url);
$this->PrivateStartSession($requestType);
}
/**
* 轉(zhuǎn)到303重定向網(wǎng)址
*
* @access public
* @param string $url 地址
* @return string
*/
function JumpOpenUrl($url)
{
$this->ResetAny();
$this->JumpCount++;
$this->m_httphead = Array() ;
$this->m_html = "";
$this->Close();
//初始化系統(tǒng)
$this->PrivateInit($url);
$this->PrivateStartSession('GET');
}
/**
* 獲得某操作錯(cuò)誤的原因
*
* @access public
* @return void
*/
function printError()
{
echo "錯(cuò)誤信息:".$this->m_error;
echo "<br/>具體返回頭:<br/>";
foreach($this->m_httphead as $k=>$v){ echo "$k => $v <br/>\r\n"; }
}
/**
* 判別用Get方法發(fā)送的頭的應(yīng)答結(jié)果是否正確
*
* @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;
}
}
/**
* 看看返回的網(wǎng)頁(yè)是否是text類(lèi)型
*
* @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 .= "內(nèi)容為非文本類(lèi)型或網(wǎng)址重定向<br/>";
return FALSE;
}
}
/**
* 判斷返回的網(wǎng)頁(yè)是否是特定的類(lèi)型
*
* @access public
* @param string $ctype 內(nèi)容類(lèi)型
* @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 .= "類(lèi)型不對(duì) ".$this->GetHead("content-type")."<br/>";
return FALSE;
}
}
/**
* 用Http協(xié)議下載文件
*
* @access public
* @param string $savefilename 保存文件名稱(chēng)
* @return string
*/
function SaveToBin($savefilename)
{
if(!$this->IsGetOK())
{
return FALSE;
}
if(@feof($this->m_fp))
{
$this->m_error = "連接已經(jīng)關(guān)閉!"; 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;
}
/**
* 保存網(wǎng)頁(yè)內(nèi)容為T(mén)ext文件
*
* @access public
* @param string $savefilename 保存文件名稱(chēng)
* @return string
*/
function SaveToText($savefilename)
{
if($this->IsText())
{
$this->SaveBinFile($savefilename);
}
else
{
return "";
}
}
/**
* 用Http協(xié)議獲得一個(gè)網(wǎng)頁(yè)的內(nèi)容
*
* @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;
}
/**
* 開(kāi)始HTTP會(huì)話(huà)
*
* @access public
* @param string $requestType 哀求類(lèi)型
* @return string
*/
function PrivateStartSession($requestType="GET")
{
if(!$this->PrivateOpenHost())
{
$this->m_error .= "打開(kāi)遠(yuǎn)程主機(jī)出錯(cuò)!";
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 = '';
//發(fā)送固定的起始哀求頭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;
//發(fā)送用戶(hù)自定義的哀求頭
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");
}
//發(fā)送固定的結(jié)束哀求頭
//HTTP1.1協(xié)議必須指定文檔結(jié)束后關(guān)閉鏈接,否則讀取文檔時(shí)無(wú)法使用feof判斷結(jié)束
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);
}
//獲取應(yīng)答頭狀態(tài)信息
$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]);
}
//獲取詳細(xì)應(yīng)答頭
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);
}
}
//如果連接被不正常關(guān)閉,重試
if(feof($this->m_fp))
{
if($this->reTry > 10)
{
return FALSE;
}
$this->PrivateStartSession($requestType);
}
//判斷是否是3xx開(kāi)頭的應(yīng)答
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 = "無(wú)法識(shí)別的答復(fù)!";
}
}
}
/**
* 獲得一個(gè)Http頭的值
*
* @access public
* @param string $headname 頭文件名稱(chēng)
* @return string
*/
function GetHead($headname)
{
$headname = strtolower($headname);
return isset($this->m_httphead[$headname]) ? $this->m_httphead[$headname] : '';
}
/**
* 設(shè)置Http頭的值
*
* @access public
* @param string $skey 鍵
* @param string $svalue 值
* @return string
*/
function SetHead($skey,$svalue)
{
$this->m_puthead[$skey] = $svalue;
}
/**
* 打開(kāi)連接
*
* @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;
}
}
/**
* 關(guān)閉連接
*
* @access public
* @return void
*/
function Close()
{
@fclose($this->m_fp);
}
/**
* 補(bǔ)全相對(duì)網(wǎng)址
*
* @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應(yīng)用希望本文所述對(duì)大家的php程序設(shè)計(jì)有所幫助.
《PHP教程:摘自織夢(mèng)CMS的HTTP文件下載類(lèi)》是否對(duì)您有啟發(fā),歡迎查看更多與《PHP教程:摘自織夢(mèng)CMS的HTTP文件下載類(lèi)》相關(guān)教程,學(xué)精學(xué)透。維易PHP學(xué)院為您提供精彩教程。
轉(zhuǎn)載請(qǐng)注明本頁(yè)網(wǎng)址:
http://www.fzlkiss.com/jiaocheng/8918.html