承接 ordinary9843/ghostscript 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

ordinary9843/ghostscript

Composer 安装命令:

composer require ordinary9843/ghostscript

包简介

Use Ghostscript to merge / split all PDF files or guess and convert PDF file version, and transform PDF into images. Fix FPDI error by Ghostscript: This document PDF probably uses a compression technique which is not supported by the free parser shipped with FPDI.

README 文档

README

build codecov Latest Stable Version Total Downloads License

If there are any features you desire, please open an issue, and I will do our best to meet your requirements!

Intro

Use Ghostscript to merge / split all PDF files or guess and convert PDF file version, and transform PDF into images. Fix FPDI error by Ghostscript: This document PDF probably uses a compression technique which is not supported by the free parser shipped with FPDI.

Cores

This library has the following features:

  • Full-featured: This library supports PDF version prediction, conversion, merger, and splitting.
  • Lower dependency on external libraries: Most Ghostscript libraries have too high a dependency on other libraries.
  • Compatible with multiple PHP versions: It can run properly on PHP 7.1 - 8.4.

Requirements

This library has the following requirements:

  • Ghostscript 9.50+

Installation

Install Ghostscript:

apt-get install ghostscript

Install ordinary9843/ghostscript:

composer require ordinary9843/ghostscript

Usage

Example usage:

<?php
require './vendor/autoload.php';

use Ordinary9843\Ghostscript;
use Ordinary9843\Constants\CompressConstant;
use Ordinary9843\Constants\GhostscriptConstant;
use Ordinary9843\Constants\ImageTypeConstant;

$file = './files/gs_ -test/test.pdf';
$binPath = '/usr/bin/gs';
$tmpPath = sys_get_temp_dir();
$ghostscript = new Ghostscript($binPath, $tmpPath);

/**
 * This function sets the path for the Ghostscript binary, which will be used for PDF processing.
 */
$ghostscript->setBinPath($binPath);

/**
 * This function sets the path for storing temporary files created during the PDF processing in Ghostscript.
 */
$ghostscript->setTmpPath($tmpPath);

/**
 * This function compresses the PDF file using the specified quality setting.
 * Supported qualities: CompressConstant::SCREEN, EBOOK (default), PRINTER, PREPRESS
 *
 * Output: './files/compress/test.pdf'
 */
$ghostscript->compress($file, CompressConstant::EBOOK);

/**
 * This function analyzes the input PDF file and returns the guessed PDF version.
 *
 * Output: 1.5
 */
$ghostscript->guess($file);

/**
 * This function converts the version of the input PDF file to the specified PDF version.
 *
 * Output: './files/convert/test.pdf'
 */
$ghostscript->convert($file, GhostscriptConstant::STABLE_VERSION);

/**
 * This function merges multiple PDF files into a single PDF file.
 * The fourth parameter $isAutoConvert (default: true) automatically converts
 * all input PDFs to a stable version before merging.
 *
 * Output: './files/merge/res.pdf'
 */
$ghostscript->merge('./files/merge', 'res.pdf', [
    './files/merge/part_1.pdf',
    './files/merge/part_2.pdf',
    './files/merge/part_3.pdf'
], true);

/**
 * This function splits a PDF file into individual pages, each saved as a separate PDF file.
 *
 * Output: [
 *   './files/split/parts/part_1.pdf',
 *   './files/split/parts/part_2.pdf',
 *   './files/split/parts/part_3.pdf'
 * ]
 */
$ghostscript->split('./files/split/test.pdf', './files/split/parts');

/**
 * This function converts each page of a PDF file into individual image files.
 * Supported types: ImageTypeConstant::JPEG, ImageTypeConstant::PNG
 *
 * Output: [
 *   './files/to-image/images/image_1.jpeg',
 *   './files/to-image/images/image_2.jpeg',
 *   './files/to-image/images/image_3.jpeg'
 * ]
 */
$ghostscript->toImage('./files/to-image/test.pdf', './files/to-image/images', ImageTypeConstant::JPEG);

/**
 * This function calculates and returns the total number of pages in a PDF file.
 *
 * Output: 3
 */
$ghostscript->getTotalPages('./files/get-total-pages/test.pdf');

/**
 * This function sets custom Ghostscript options appended to the shell command.
 */
$ghostscript->setOptions(['-dPDFSETTINGS' => '/ebook']);

/**
 * This function returns the currently configured Ghostscript options.
 *
 * Output: ['-dPDFSETTINGS' => '/ebook']
 */
$ghostscript->getOptions();

/**
 * Clear temporary files generated during the PDF processing.
 * $isForceClear = true removes all tmp files immediately regardless of age.
 * $days specifies the age threshold in days (default: 7).
 */
$ghostscript->clearTmpFiles();
$ghostscript->clearTmpFiles(true);
$ghostscript->clearTmpFiles(false, 30);

Testing

Copy the .env.example to .env:

cp .env.example .env

Run the tests:

composer test

Licenses

(The MIT License)

统计信息

  • 总下载量: 23.67k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 2
  • 点击次数: 20
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 1
  • Watchers: 1
  • Forks: 1
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2021-11-18

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固