• 技术文章 >后端开发 >php教程

    解析php下载远程图片函数 可伪造来路_PHP

    2016-06-01 12:05:46原创305
    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);
    复制代码 代码如下:
    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.1\r\n";
    $sessionQuery .= "Host: $ghost\r\n";
    $sessionQuery .= "Referer: $rfurl\r\n";
    $sessionQuery .= "Accept: */*\r\n";
    $sessionQuery .= "User-Agent: Mozilla/4.0 (compatible; MSIE 5.00; Windows 98)\r\n";
    if($gcookie!="" && !preg_match("/[\r\n]/", $gcookie))
    {
    $sessionQuery .= $gcookie."\r\n";
    }
    $sessionQuery .= "Connection: Keep-Alive\r\n\r\n";
    $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 {
    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.1\r\n";
    $sessionQuery .= "Host: $ghost\r\n";
    $sessionQuery .= "Accept: */*\r\n";
    $sessionQuery .= "User-Agent: Mozilla/4.0 (compatible; MSIE 5.00; Windows 98)\r\n";
    $sessionQuery .= "Connection: Close\r\n\r\n";
    $errno = "";
    $errstr = "";
    $m_fp = fsockopen($ghost, 80, $errno, $errstr,10) or die($ghost.'
    ');
    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'] = "//m.sbmmt.com/m/".preg_replace("/^([^\/]*)\//i", "", $gurl);
    return $garr;
    }
    ?>
    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    上一篇:提升PHP性能的21种方法介绍_PHP 下一篇:关于js与php互相传值的介绍_PHP
    20期PHP线上班

    相关文章推荐

    精选22门好课,价值3725元,开通VIP免费学习!• 细思极恐?关于in_array的第3个参数• PHP 第三节 变量介绍_PHP• PHP排序算法的复习和总结_PHP• IIS下PHP的三种配置方式比较_PHP• 对text数据类型不支持代码页转换 从: 1252 到: 936_PHP
    1/1

    PHP中文网