PHP实现的下载远程图片自定义函数分享

yipeiwu_com5年前PHP代码库

复制代码 代码如下:

<?php
/**
 * PHP下载远程图片到本地
 *
 * @param $url string 远程文件地址
 * @param $filename string 保存后的文件名(为空时则为随机生成的文件名,否则为原文件名)
 * @param $fileType array 允许的文件类型
 * @param $dirName string 文件保存的路径(路径其余部分根据时间系统自动生成)
 * @param $type int 远程获取文件的方式
 * @return json 返回文件名、文件的保存路径
 * @author blog.snsgou.com
 */
function getImage($url, $fileName = '', $dirName, $fileType = array('jpg', 'gif'), $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 = 15; // 超时时间
  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()) . '/';
 if (!file_exists($dirName))
 {
  mkdir($dirName, 0777, true);
 }

 // 保存文件
 $res = fopen($dirName . $fileName, 'a');
 fwrite($res, $file);
 fclose($res);

 return "{'fileName':$fileName, 'saveDir':$dirName}";
}


// 举例
// 返回:{'fileName':13668030896.jpg, 'saveDir':/www/test/img/2013/04/24/}
echo getImage('/zb_users/upload/202003/wjkljl30xvl.jpg', '', 'd:/PHP/data', array('jpg', 'gif'), 1);

相关文章

关于PHP中协程和阻塞的一些理解与思考

前言 本文主要给大家介绍了关于PHP中协程和阻塞的理解与思考,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍: 进程、线程、协程 关于进程、线程、协程,有非常详细和丰富的...

PHP遍历XML文档所有节点的方法

本文实例讲述了PHP遍历XML文档所有节点的方法。分享给大家供大家参考。具体实现方法如下: 1. contact.xml代码: <contact id="43956">...

PHP检测字符串是否为UTF8编码的常用方法

本文实例总结了PHP检测字符串是否为UTF8编码的常用方法。分享给大家供大家参考。具体实现方法如下: 检测字符串编码可以有很多种方法,如利用ord获得字符的进制然后进入判断,或利用mb_...

PHP读取txt文件的内容并赋值给数组的代码

2010-12-15.txt的文件内容如下: 复制代码 代码如下: 01 02 03 04 05 06 07 08 09 10 11 12 13 14 15 16 17 18 19 20...

浅谈php(codeigniter)安全性注意事项

1、httponly session一定要用httponly的否则可能被xxs攻击,利用js获取cookie的session_id。 要用框架的ci_session,更长的位数,http...