0

所以我有一个 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 行负责生成巨大的文件。

知道如何解决这个问题吗?

4

0 回答 0