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


Posted in PHP onJune 25, 2013

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.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<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.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.'<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;
}
?>

PHP 相关文章推荐
PHP 反射机制实现动态代理的代码
Oct 22 PHP
php数组一对一替换实现代码
Aug 31 PHP
PHP输出当前进程所有变量/常量/模块/函数/类的示例
Nov 07 PHP
destoon利用Rewrite规则设置网站安全
Jun 21 PHP
PHP记录搜索引擎蜘蛛访问网站足迹的方法
Apr 15 PHP
分享PHP守护进程类
Dec 30 PHP
[原创]php实现子字符串位置相互对调互换的方法
Jun 02 PHP
php+resumablejs实现的分块上传 断点续传功能示例
Apr 18 PHP
PHPMAILER实现PHP发邮件功能
Apr 18 PHP
thinkPHP5框架路由常用知识点汇总
Sep 15 PHP
PHP实现单条sql执行多个数据的insert语句方法
Oct 11 PHP
WordPress多语言翻译插件 - WPML使用教程
Apr 01 PHP
解析php通过cookies获取远程网页的指定代码
Jun 25 #PHP
使用dump函数,给php加断点测试
Jun 25 #PHP
解析php多线程下载远程多个文件
Jun 25 #PHP
基于php导出到Excel或CSV的详解(附utf8、gbk 编码转换)
Jun 25 #PHP
执行、获取远程代码返回:file_get_contents 超时处理的问题详解
Jun 25 #PHP
PHP 冒泡排序 二分查找 顺序查找 二维数组排序算法函数的详解
Jun 25 #PHP
使用php判断网页是否gzip压缩
Jun 25 #PHP
You might like
php socket方式提交的post详解
2008/07/19 PHP
thinkPHP引入类的方法详解
2016/12/08 PHP
Yii2框架可逆加密简单实现方法
2017/08/25 PHP
JavaScript 撑出页面文字换行
2009/06/15 Javascript
实现checkbox全选、反选、取消JavaScript小脚本异常
2014/04/10 Javascript
PhotoShop给图片自动添加边框及EXIF信息的JS脚本
2015/02/15 Javascript
推荐10 款 SVG 动画的 JavaScript 库
2015/03/24 Javascript
NodeJS创建基础应用并应用模板引擎
2016/04/12 NodeJs
JS实现环形进度条(从0到100%)效果
2016/07/05 Javascript
jQuery实现鼠标选中文字后弹出提示窗口效果【附demo源码】
2016/09/05 Javascript
vuejs指令详解
2017/02/07 Javascript
angular实现图片懒加载实例代码
2017/06/08 Javascript
详解webpack+vue-cli项目打包技巧
2017/06/17 Javascript
JScript实现表格的简单操作
2017/08/15 Javascript
JavaScript实现二叉树的先序、中序及后序遍历方法详解
2017/10/26 Javascript
nodejs实现大文件(在线视频)的读取
2020/10/16 NodeJs
jquery获取元素到屏幕四周可视距离的方法
2018/09/05 jQuery
详解ES6中的Map与Set集合
2019/03/22 Javascript
在Python中使用dict和set方法的教程
2015/04/27 Python
python开发之for循环操作实例详解
2015/11/12 Python
举例讲解Python的lambda语句声明匿名函数的用法
2016/07/01 Python
用virtualenv建立多个Python独立虚拟开发环境
2017/07/06 Python
Flask项目中实现短信验证码和邮箱验证码功能
2019/12/05 Python
Pycharm 2020年最新激活码(亲测有效)
2020/09/18 Python
Python 读取有公式cell的结果内容实例方法
2020/02/17 Python
基于Python3.7.1无法导入Numpy的解决方式
2020/03/09 Python
Django+Django-Celery+Celery的整合实战
2021/01/20 Python
Linux系统下升级pip的完整步骤
2021/01/31 Python
Python字符串的15个基本操作(小结)
2021/02/03 Python
英国第二大营养品供应商:Vitabiotics
2016/10/01 全球购物
BIBLOO捷克:购买女装、男装、童装、鞋和配件
2017/01/27 全球购物
微软巴西官方网站:Microsoft Brasil
2019/09/26 全球购物
如何提高JDBC的性能
2013/04/30 面试题
学校七一活动方案
2014/01/19 职场文书
学生会竞选演讲稿学习部
2014/08/25 职场文书
python开发飞机大战游戏
2021/07/15 Python