定制 blaspsoft/doxswap 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

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

blaspsoft/doxswap

最新稳定版本:v1.0.2

Composer 安装命令:

composer require blaspsoft/doxswap

包简介

Doxswap is a simple document conversion package for Laravel which uses LibreOffice to convert documents to a variety of formats.

README 文档

README

Onym Icon

GitHub Workflow Status (main) Total Downloads Latest Version License

Doxswap

A Laravel package for seamless document and image format conversions. Transform between various formats like DOCX -> PDF, HTML -> PDF, PNG -> WEBP, and more popular formats using a simple, elegant API. Powered by LibreOffice for documents and ImageMagick for image processing.

???? Features

  • ???? Multiple Format Support – Convert between documents (DOCX, XLSX, ODT) and images (PNG, JPG, WEBP) with ease
  • ???? Simple API – Easy-to-use interface for all conversion operations
  • ???? Laravel Storage Integration – Works seamlessly with Laravel's filesystem drivers
  • Efficient Processing – Optimized conversion using LibreOffice and ImageMagick engines
  • ???? Conversion Tracking – Detailed results including duration and file paths
  • ???? Secure File Handling – Safe and secure file processing with proper cleanup
  • ⚙️ Configurable Settings – Customize paths, storage disks, and conversion options
  • ????️ Error Handling – Robust exception handling for unsupported formats and conversions

Installation

You can install the package via composer:

composer require blaspsoft/doxswap

You can publish the config file with:

php artisan vendor:publish --tag="doxswap-config"

Overview

The config/doxswap.php file includes:

???? Storage & Cleanup

  • input_disk: Where to read files from (default: 'public')
  • output_disk: Where to save converted files (default: 'public')
  • perform_cleanup: Delete input files after conversion (default: false)

???? File Naming

Configure how output files are named using different strategies:

'filename' => [ // Strategy: 'original', 'random', or 'timestamp' 'strategy' => 'original', // Naming options 'options' => [ 'length' => 24, // Length for random names 'prefix' => '', // Add prefix to filename 'suffix' => '', // Add suffix to filename 'separator' => '_', // Separator for components 'format' => 'YmdHis', // Format for timestamp strategy ], ]

????️ Conversion Drivers

Configure paths for conversion tools:

'drivers' => [ 'libreoffice_path' => env('LIBRE_OFFICE_PATH', '/usr/bin/soffice'), ]

Default LibreOffice paths by OS:

  • ???? Linux: /usr/bin/soffice
  • ???? macOS: /Applications/LibreOffice.app/Contents/MacOS/soffice
  • ???? Windows: C:\Program Files\LibreOffice\program\soffice.exe

???? File Types

Supports various document formats including:

  • Documents: DOC, DOCX, ODT, RTF, TXT
  • Spreadsheets: XLS, XLSX, ODS, CSV
  • Presentations: PPT, PPTX, ODP
  • Images: JPG, PNG, SVG, BMP, TIFF, WEBP, GIF
  • Web: HTML, XML
  • Other: PDF

Usage

$result = Doxswap::convert('sample.docx', 'pdf'); /**  * Returns a ConversionResult object with the following properties:  *  * @property string $inputFilename The original input filename  * @property string $inputFilePath The full path to the input file  * @property string $outputFilename The converted output filename  * @property string $outputFilePath The full path to the converted output file  * @property string $toFormat The format the file was converted to (e.g. 'pdf')  * @property string $duration The time taken for conversion (e.g. "2.21 sec")  * @property float $startTime Unix timestamp of when conversion started  * @property float $endTime Unix timestamp of when conversion completed  * @property string $inputDisk The Laravel storage disk used for input  * @property string $outputDisk The Laravel storage disk used for output  */

Requirements

LibreOffice & ImageMagick

This package requires LibreOffice, ImageMagick, and Potrace to be installed on your system. Here's how to install them:

Ubuntu/Debian

sudo apt update sudo apt install libreoffice imagemagick potrace

macOS

brew install libreoffice imagemagick potrace

Windows

choco install libreoffice imagemagick potrace

Docker

If you're using Docker, you can add the required dependencies to your container:

# Ubuntu/Debian based RUN apt-get update && apt-get install -y libreoffice imagemagick potrace # Alpine based RUN apk add --no-cache libreoffice imagemagick potrace

PHP Requirements

  • PHP >= 8.1
  • ext-fileinfo
  • ext-imagick
  • Laravel >= 9.0

???? Supported Conversions by Category

???? Documents

From Supported Conversions
DOCX PDF ✅✅, ODT, RTF, TXT, HTML, XML, EPUB
DOC PDF ✅✅, DOCX, ODT, RTF, TXT, HTML, XML, EPUB
ODT PDF, DOCX, RTF, TXT, HTML, XML
RTF PDF, DOCX, ODT, TXT, HTML, XML
TXT PDF, DOCX, ODT, HTML, XML
HTML PDF, ODT, TXT
XML PDF, DOCX, ODT, TXT, HTML

???? Spreadsheets

From Supported Conversions
XLSX PDF ✅✅, ODS, CSV
XLS PDF, XLSX, ODS, CSV
ODS PDF, XLSX, CSV
CSV PDF, XLSX, ODS

???? Presentations

From Supported Conversions
PPTX PDF ✅✅, ODP
PPT PDF, PPTX, ODP
ODP PDF, PPTX

????️ Images

From Supported Conversions
PNG PDF ✅, JPG, SVG, TIFF, WEBP, GIF, BMP
JPG PDF ✅, PNG, SVG, TIFF, WEBP, GIF, BMP
SVG PDF, PNG, JPG, TIFF, WEBP, GIF, BMP
BMP PDF, PNG, JPG, SVG, TIFF, WEBP, GIF
TIFF PDF, PNG, JPG, SVG, WEBP, GIF, BMP
WEBP PDF, PNG, JPG, SVG, TIFF, GIF, BMP
GIF PDF, PNG, JPG, SVG, TIFF, WEBP, BMP

Legend ????

  • ✅✅ = Common high-priority conversion
  • ✅ = Popular supported format
  • (unlisted) = Conversion not supported

Note: Document conversions are performed using LibreOffice in headless mode, while image format conversions utilize ImageMagick ????

???? Sponsors

If you find this package helpful, please consider sponsoring the development:

???? Become a GitHub Sponsor

License

Blasp is open-sourced software licensed under the MIT license.

统计信息

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

GitHub 信息

  • Stars: 225
  • Watchers: 5
  • Forks: 19
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-01-04

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固