首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >imagecreatefrompng获取外部镜像安全吗?

imagecreatefrompng获取外部镜像安全吗?
EN

Stack Overflow用户
提问于 2014-10-30 02:54:13
回答 1查看 160关注 0票数 0

我想知道来自and的函数imagecreatefrompng (和它的相关函数)是否安全?

例如,如果我使用此函数获取外部图像文件,并且图像包含恶意代码,则此代码会在我的服务器上执行吗?

示例:

代码语言:javascript
复制
 <?php
if($_GET['pass'] != 'IamAW') die();

// Accepted Filetypes
$Accepted = array('png');

$File = $_GET['file'];

$Filetype = end(explode('.', $File));

if(!in_array($Filetype, $Accepted)) {
die('Fil-type ikke valid');
}

$im = imagecreatefrompng($File);


header('Content-Type: image/'. $Filetype);
imagepng($im);

imagedestroy($im);
?>
EN

回答 1

Stack Overflow用户

发布于 2014-10-30 03:13:15

这是可行的,但为什么还要费心呢?

您正在吸收一个远程PNG,在内存中解压缩为原始格式,然后重新压缩为PNG,而无需对图像做任何操作。如果它最终是一个“大”的PNG (例如,一个1280x1024 32位的PNG需要5兆字节的内存),你就有耗尽内存的风险。

你最好这样做:

代码语言:javascript
复制
echo file_get_contents($remote_image_url);

为您节省解压缩/重新压缩的时间。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/26638417

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档