所以我有一个 php 脚本,它接受 PDF 并将其转换为 JPEG 图像。直到今天一切都很好,但是今天我得到了这个 PDF,由于某种原因导致在我的/tmp
目录中生成了非常大的文件(比如 ~14 gigs,而 PDF 文件本身是 ~18MB)。
这是有问题的PDF:
https://www.ciamarket.lt/sites/default/files//failai/leidinys_01.15-28-compressed.pdf
这是相关代码:
<?php
$userAgent = 'Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/67.0.3396.99 Safari/537.36';
$response = $this
->httpClient
->request(
'GET',
$url,
[
'headers' => [
'User-Agent' => $userAgent,
],
]
);
$contents = $response->getBody()->getContents();
$tmpFilePath = tempnam(sys_get_temp_dir(), 'brochure_s');
$tmpFile = fopen($tmpFilePath, 'r+');
fwrite($tmpFile, $contents);
while (true) {
try {
$image = new \Gmagick();
$image->setResolution($width, $height);
$image->readimage($tmpFilePath . '[' . $i . ']');
$image->setImageFormat('jpeg');
$image->setCompressionQuality(75);
$image->resizeImage($width, $height, \Gmagick::FILTER_LANCZOS, 1, false);
$imageBlob = $image->getImageBlob();
$this
->uploader
->uploadData(
$imageBlob,
$brochureId,
'',
'jpg'
);
$image->destroy();
} catch (\Throwable $t) {
break;
}
}
我从我的脚本中提取了相关位。
我认为第 28 行负责生成巨大的文件。
知道如何解决这个问题吗?