Skip to content

Compress PDF

Reduce PDF file size by downsampling embedded images. Choose between a quality slider or a target file size.

API Endpoint

POST /api/v1/tools/compress-pdf

Accepts multipart form data with a PDF file and a JSON settings field.

Parameters

ParameterTypeRequiredDefaultDescription
modestringNo"quality"Compression mode: quality or targetSize
qualityintegerNo75Compression quality, 1-100 (higher = less compression). Used in quality mode
targetSizeKbnumberNo-Target file size in kilobytes. Used in targetSize mode

Example Request

Compress by quality:

bash
curl -X POST http://localhost:1349/api/v1/tools/compress-pdf \
  -H "Authorization: Bearer si_your-api-key" \
  -F "[email protected]" \
  -F 'settings={"mode": "quality", "quality": 60}'

Compress to a target size:

bash
curl -X POST http://localhost:1349/api/v1/tools/compress-pdf \
  -H "Authorization: Bearer si_your-api-key" \
  -F "[email protected]" \
  -F 'settings={"mode": "targetSize", "targetSizeKb": 500}'

Example Response

json
{
  "jobId": "a1b2c3d4-e5f6-7890-abcd-ef1234567890",
  "downloadUrl": "/api/v1/download/a1b2c3d4-e5f6-7890-abcd-ef1234567890/document.pdf",
  "originalSize": 5200000,
  "processedSize": 1800000
}

Notes

  • In quality mode, lower values produce smaller files with more image degradation.
  • In targetSize mode, a binary search finds the highest DPI that fits the requested size.
  • If compression would enlarge the file, the original bytes are returned unchanged.
  • Text and vector content are not affected; only embedded raster images are downsampled.