/**
* 下载远程图片到本地
*
* @param string $url 远程文件地址
* @param string $filenNme 保存后的文件名(为空时则为随机生成的文件名,否则为原文件名)
* @param array $fileType 允许的文件类型
* @param string $dirName 文件保存的路径(路径其余部分根据时间系统自动生成)
* @param int $type 远程获取文件的方式
* @return json 返回文件名、文件的保存路径
* @author 52php.cnblogs.com
*/
function download_image($url, $fileName = '', $dirName, $fileType = array('jpg', 'gif', 'png'), $type = 1)
{
if ($url == '')
{
return false;
} // 获取文件原文件名
$defaultFileName = basename($url); // 获取文件类型
$suffix = substr(strrchr($url, '.'), 1);
if (!in_array($suffix, $fileType))
{
return false;
} // 设置保存后的文件名
$fileName = $fileName == '' ? time() . rand(0, 9) . '.' . $suffix : $defaultFileName; // 获取远程文件资源
if ($type)
{
$ch = curl_init();
$timeout = 30;
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, $timeout);
$file = curl_exec($ch);
curl_close($ch);
}
else
{
ob_start();
readfile($url);
$file = ob_get_contents();
ob_end_clean();
} // 设置文件保存路径
//$dirName = $dirName . '/' . date('Y', time()) . '/' . date('m', time()) . '/' . date('d', time());
$dirName = $dirName . '/' . date('Ym', time());
if (!file_exists($dirName))
{
mkdir($dirName, 0777, true);
} // 保存文件
$res = fopen($dirName . '/' . $fileName, 'a');
fwrite($res, $file);
fclose($res); return array(
'fileName' => $fileName,
'saveDir' => $dirName
);
}

实战经历:

博客中有些图片是直接引用其他网站的,这些天不知道咋地,估计是对方做了防盗链操作,导致博客中的图片显示不出来,没办法,只好用PHP批量采集下来,并且批量替换博文中的图片地址:

/**
* 批量下载博客中的图片到本地
*/
public function index()
{
global $_G; $blogModel = model('Blog', 'blog');
$list = $blogModel->order('gid desc')->limit(10)->findPage(); $page = get_gpc('page') ? get_gpc('page') : 1;
$totalPages = $list['totalPages'];
$page = $page + 1; if ($page > $totalPages)
{
die('更新完毕!');
} foreach ($list['data'] as $val)
{
$content = $val['content'];
$excerpt = $val['excerpt']; $_G['isContentUpdate'] = $_G['isExcerptUpdate'] = false; /* 内容 */
$content = preg_replace_callback("/src=\"(http:\/\/images\.cnblogs\.com\/cnblogs_com[^\"]+)\"/", function($matches) { global $_G;
$_G['isContentUpdate'] = true; // 下载远程图片到本地
$res = download_image($matches[1], 'old', 'd:/PHP/xampp/htdocs/emlog/data/upload'); // 返回 下载后的图片url地址
return 'src="/data/upload/' . date('Ym', time()) . '/' . $res['fileName'] . '"'; }, $content); /* 摘要 */
$excerpt = preg_replace_callback("/src=\"(http:\/\/images\.cnblogs\.com\/cnblogs_com[^\"]+)\"/", function($matches) { global $_G;
$_G['isExcerptUpdate'] = true; // 下载远程图片d到本地
$res = download_image($matches[1], 'old', 'd:/PHP/xampp/htdocs/emlog/data/upload'); // 返回 下载后的图片url地址
return 'src="/data/upload/' . date('Ym', time()) . '/' . $res['fileName'] . '"'; }, $excerpt); /* 更新数据库 */
$where = array(
'gid' => $val['gid']
);
$data = array(); if ($_G['isContentUpdate'])
{
$data['content'] = $content;
} if ($_G['isExcerptUpdate'])
{
$data['excerpt'] = $excerpt;
} if ($data)
{
$blogModel->where($where)->save($data);
}
} /* 更新下一页 */
$url = url('blog/Main/index', array('page' => $page));
$msg = '正在更新' . $page . '/' . $totalPages;
redirect($url, 2, $msg);
}

PHP下载/采集远程图片到本地的更多相关文章

  1. [PHP学习教程 - 网络]001.下载/采集远程文件到本地(Download File)

    引言:如何把http://mzitu.com里的图片全部下载下来呢? 一身浩然正气的AC陷入的深思.... 当然这里涉及到的功能有线程,网页请求,页面提取,下载图片等等.今天,我们先讲一下如何下载文件 ...

  2. php下载远程图片到本地

    在使用 PHP 做简单的爬虫的时候,我们经常会遇到需要下载远程图片的需求,所以下面来简单实现这个需求1:使用curl 比如我们有下面这两张图片: $images = [ 'https://img.al ...

  3. curl获取远程图片存到本地

    $url = 'http://sssss/sss/xu0fLo9waqKSTDO7j0kSO41O5Luq3LB6ozUvY4O7OsXUWNicB49fBs8nGYzoqcwGDARQZHpVuic ...

  4. thinkphp下载远程图片到本地

    $url="http://www.test.com/test.jpg";//图片远程地址 $local="./Upload/test/test.jpg";//下 ...

  5. PHP通过url下载远程图片到本地

    function GrabImage($url,$filename) { if($url==""):return false;endif; ob_start(); readfile ...

  6. PHP下载远程图片到本地的几种方法总结(tp5.1)

    1.CURL 2.使用file_get_contents 3.使用fopen 参考链接:https://www.jb51.net/article/110615.htm

  7. php下保存远程图片到本地的函数

    <?php header("content-type:text/html;charset=utf-8"); function GrabImage($url,$filename ...

  8. PHP抓取远程图片到本地保存(如何把错误信息用text文件写入)

    最近在工作中需要开发了一个用户素材功能,里面需要将网上的各种图片素材进行本地化存储.于是在网上找了一些相关资料,并根据自身开发需要,整理了一下主要的逻辑代码. /** * PHP将网页上的图片攫取到本 ...

  9. php采集远程图片

随机推荐

  1. qemu中是怎么模拟的新的设备

    kvm_cpu_exec 和demo中演示的一样

  2. IPv4地址分类及特征

    IPv4地址分类及特征 IP地址后斜杠和数字代表的意思 其中有这样一个IP地址的格式:IP/数字,例如:111.222.111.222/24 这种格式平时在内网中用的不多,所以一下子看不懂,最后查了资 ...

  3. 【CZY选讲·最大子矩阵和】

    题目描述 有一个n*m的矩阵,恰好改变其中一个数变成给定的常数P,使得改变后的这个矩阵的最大子矩阵最大. 数据范围 n,m<=300. 题解:    ①如果没有p,那么二维矩阵和就是一维最长 ...

  4. css实现0.5像素

    .border{ position: relative; } .border:before{ content: ''; position: absolute; width: 200%; height: ...

  5. 每天一个小算法(Shell Sort1)

    希尔排序是1959 年由D.L.Shell 提出来的,相对直接排序有较大的改进.希尔排序又叫缩小增量排序 基本思想: 先将整个待排序的记录序列分割成为若干子序列分别进行直接插入排序,待整个序列中的记录 ...

  6. saltstack 实现haproxy+keepalived

    1.目录结构规划如下 mkdir -p /srv/salt/prod/haproxy mkdir -p /srv/salt/prod/keepalived mkdir -p /srv/salt/pro ...

  7. oracle查询时遇到的坑

    select * from manu_routecard t left join manu_routecardlist mr on t.routecard_id = mr.routecard_id l ...

  8. ztree 2.0 节点搜索

    最近做了一个简单的功能,树节点的搜索.ztree的版本的2.0,3.X以上的版本请百度解决办法. 1.在setting中增加 function getFontCss(treeId, treeNode) ...

  9. eclipse搭建ssm框架的maven的工程

    版本:eclipse:Indigo Service Release 2.  jdk :jdk1.7.0_03. maven:apache-maven-3.3.3 . 上面的3个东西 先下载下来.然后运 ...

  10. 在Framework2.0环境下运行3.5的代码

    因为许多的服务器特别是廉价的服务器上使用的是Framework的v2.0.50727.再加上自己开发的算是产品,所以就需要降低一些客户的前期成本,而自己同时也喜欢简单的代码.后来查了下,得知其实Fra ...