PHPExcel 生成图片导出(保存网络图片到本地再输出)

#########################生成图片#########################

$value = iconv("UTF-8", "GB2312", $v['img']); //防止中文命名的文件
// 图片生成
$objDrawing[$k] = new \PHPExcel_Worksheet_Drawing();
$value=strstr($value,'/images');
$this->crabImage($v['img']);
// $value=$_SERVER["DOCUMENT_ROOT"].'/images/major_img/2019-06-12/new15603443457002.jpeg';
$value=$_SERVER["DOCUMENT_ROOT"].$value;
$objDrawing[$k]->setPath($value);
// 设置宽度高度
$objDrawing[$k]->setHeight(90);//照片高度
$objDrawing[$k]->setWidth(90); //照片宽度
/*设置图片要插入的单元格*/
$objDrawing[$k]->setCoordinates('E'.$k);
// 图片偏移距离
$objDrawing[$k]->setOffsetX(12);
$objDrawing[$k]->setOffsetY(12);
$objDrawing[$k]->setWorksheet($this->objPHPExcel->getActiveSheet());

 

/**
 * PHP将网页上的图片攫取到本地存储
 * @param $imgUrl  图片url地址
 * @param string $saveDir 本地存储路径 默认存储在当前路径
 * @param null $fileName 图片存储到本地的文件名
 * @return mix
 */
public function crabImage($imgUrl){

    if(empty($imgUrl)){
        return false;
    }
    //获取图片信息大小
    $imgSize = getImageSize($imgUrl);
    if(!in_array($imgSize['mime'],array('image/jpg', 'image/gif', 'image/png', 'image/jpeg'),true)){
        return false;
    }
    //获取后缀名
    $_mime = explode('/', $imgSize['mime']);
    $_ext = '.'.end($_mime);
    //生成唯一的文件名
    $filename = strstr($imgUrl, '/images');
    //开始攫取
    ob_start();
    readfile($imgUrl);
    $imgInfo = ob_get_contents();
    ob_end_clean();

    $fp = fopen($_SERVER["DOCUMENT_ROOT"].$filename, 'a');
    $imgLen = strlen($imgInfo);    //计算图片源码大小
    $_inx = 1024;   //每次写入1k
    $_time = ceil($imgLen/$_inx);
    for($i=0; $i<$_time; $i++){
        fwrite($fp,substr($imgInfo, $i*$_inx, $_inx));
    }
    fclose($fp);
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值