程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> 解析php下載遠程圖片函數 可偽造來路

解析php下載遠程圖片函數 可偽造來路

編輯:關於PHP編程

    gurl 要下載的圖片地址
    $rfurl 來路。如果目標圖像做了防盜鏈設置,可以繞過。
    $filename 下載圖片保存的文件名,相對路徑,不要用realpath
    $gcookie 調整cookie 偽造的cookie
    $JumpCount 跳轉計數
    $maxtime 最大次數
    調用方法:DownImageKeep(“http://www.baidu.com/img/baidu_jgylogo2.gif”,”http://baidu.com”,”a.gif”,”",0,10);

    復制代碼 代碼如下:
    <?php
    function DownImageKeep($gurl, $rfurl, $filename, $gcookie="", $JumpCount=0, $maxtime=30)
    {
    $urlinfos = GetHostInfo($gurl);
    $ghost = trim($urlinfos['host']);
    if($ghost=='')
    {
    return FALSE;
    }
    $gquery = $urlinfos['query'];
    if($gcookie=="" && !empty($rfurl))
    {
    $gcookie = RefurlCookie($rfurl);
    }
    $sessionQuery = "GET $gquery HTTP/1.1rn";
    $sessionQuery .= "Host: $ghostrn";
    $sessionQuery .= "Referer: $rfurlrn";
    $sessionQuery .= "Accept: */*rn";
    $sessionQuery .= "User-Agent: Mozilla/4.0 (compatible; MSIE 5.00; Windows 98)rn";
    if($gcookie!="" && !preg_match("/[rn]/", $gcookie))
    {
    $sessionQuery .= $gcookie."rn";
    }
    $sessionQuery .= "Connection: Keep-Alivernrn";
    $errno = "";
    $errstr = "";
    $m_fp = fsockopen($ghost, 80, $errno, $errstr,10);
    fwrite($m_fp,$sessionQuery);
    $lnum = 0;
    //獲取詳細應答頭
    $m_httphead = Array();
    $httpstas = explode(" ",fgets($m_fp,256));
    $m_httphead["http-edition"] = trim($httpstas[0]);
    $m_httphead["http-state"] = trim($httpstas[1]);
    while(!feof($m_fp))
    {
    $line = trim(fgets($m_fp,256));
    if($line == "" || $lnum>100)
    {
    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!="")
    {
    $m_httphead[strtolower($hkey)] = trim($hvalue);
    }
    }
    //分析返回記錄
    if(preg_match("/^3/", $m_httphead["http-state"]))
    {
    if(isset($m_httphead["location"]) && $JumpCount<3)
    {
    $JumpCount++;
    DownImageKeep($gurl,$rfurl,$filename,$gcookie,$JumpCount);
    }
    else
    {
    return FALSE;
    }
    }
    if(!preg_match("/^2/", $m_httphead["http-state"]))
    {
    return FALSE;
    }
    if(!isset($m_httphead))
    {
    return FALSE;
    }
    $contentLength = $m_httphead['content-length'];
    //保存文件
    $fp = fopen($filename,"w") or die("寫入文件:{$filename} 失敗!");
    $i=0;
    $okdata = "";
    $starttime = time();
    while(!feof($m_fp))
    {
    $okdata .= fgetc($m_fp);
    $i++;
    //超時結束
    if(time()-$starttime>$maxtime)
    {
    break;
    }
    //到達指定大小結束
    if($i >= $contentLength)
    {
    break;
    }
    }
    if($okdata!="")
    {
    fwrite($fp,$okdata);
    }
    fclose($fp);
    if($okdata=="")
    {
    @unlink($filename);
    fclose($m_fp);
    return FALSE;
    }
    fclose($m_fp);
    return TRUE;
    }
    /**
    * 獲得某頁面返回的Cookie信息
    *
    * @access public
    * @param string $gurl 調整地址
    * @return string
    */
    function RefurlCookie($gurl)
    {
    global $gcookie,$lastRfurl;
    $gurl = trim($gurl);
    if(!empty($gcookie) && $lastRfurl==$gurl)
    {
    return $gcookie;
    }
    else
    {
    $lastRfurl=$gurl;
    }
    if(trim($gurl)=='')
    {
    return '';
    }
    $urlinfos = GetHostInfo($gurl);
    $ghost = $urlinfos['host'];
    $gquery = $urlinfos['query'];
    $sessionQuery = "GET $gquery HTTP/1.1rn";
    $sessionQuery .= "Host: $ghostrn";
    $sessionQuery .= "Accept: */*rn";
    $sessionQuery .= "User-Agent: Mozilla/4.0 (compatible; MSIE 5.00; Windows 98)rn";
    $sessionQuery .= "Connection: Closernrn";
    $errno = "";
    $errstr = "";
    $m_fp = fsockopen($ghost, 80, $errno, $errstr,10) or die($ghost.'<br />');
    fwrite($m_fp,$sessionQuery);
    $lnum = 0;
    //獲取詳細應答頭
    $gcookie = "";
    while(!feof($m_fp))
    {
    $line = trim(fgets($m_fp,256));
    if($line == "" || $lnum>100)
    {
    break;
    }
    else
    {
    if(preg_match("/^cookie/i", $line))
    {
    $gcookie = $line;
    break;
    }
    }
    }
    fclose($m_fp);
    return $gcookie;
    }
    /**
    * 獲得網址的host和query部份
    *
    * @access public
    * @param string $gurl 調整地址
    * @return string
    */
    function GetHostInfo($gurl)
    {
    $gurl = preg_replace("/^http:///i", "", trim($gurl));
    $garr['host'] = preg_replace("//(.*)$/i", "", $gurl);
    $garr['query'] = "/".preg_replace("/^([^/]*)//i", "", $gurl);
    return $garr;
    }
    ?>
    1. 上一頁:
    2. 下一頁:
    Copyright © 程式師世界 All Rights Reserved