shotapi / shotapi-php
Official PHP SDK for ShotAPI - Screenshot & Rendering API
1.0.0
2026-02-06 10:34 UTC
Requires
- php: >=7.4
- ext-curl: *
- ext-json: *
README
Official PHP SDK for ShotAPI - The Screenshot & Rendering API.
Requirements
- PHP 7.4 or higher
- cURL extension
- JSON extension
Installation
composer require shotapi/shotapi-php
Or add to your composer.json:
{
"require": {
"shotapi/shotapi-php": "^1.0"
}
}
Quick Start
<?php require 'vendor/autoload.php'; use ShotAPI\Client; $client = new Client('sk_your_api_key'); // Take a screenshot $image = $client->screenshot('https://example.com'); file_put_contents('screenshot.png', $image);
Usage Examples
Basic Screenshot
$client = new Client('sk_your_api_key'); // Simple screenshot $image = $client->screenshot('https://stripe.com'); // Full-page screenshot with options $image = $client->screenshot('https://github.com', [ 'fullPage' => true, 'format' => 'png', 'width' => 1920, 'height' => 1080, ]); // Dark mode with retina $image = $client->screenshot('https://example.com', [ 'darkMode' => true, 'deviceScaleFactor' => 2, 'blockAds' => true, ]);
Device Mockups
// iPhone mockup $image = $client->screenshot('https://example.com', [ 'mockup' => 'iphone', ]); // MacBook mockup $image = $client->screenshot('https://example.com', [ 'mockup' => 'macbook', ]);
HTML to Image
$html = <<<HTML <div style="padding: 40px; background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);"> <h1 style="color: white; font-family: sans-serif;">Hello World!</h1> </div> HTML; $image = $client->render($html, [ 'width' => 800, 'height' => 400, ]);
Metadata Extraction
// Get page metadata $meta = $client->metadata('https://github.com'); echo $meta['title']; echo $meta['description']; echo $meta['og_image']; // With markdown content $meta = $client->metadata('https://example.com', [ 'extractMarkdown' => true, ]); echo $meta['markdown'];
Batch Screenshots
$urls = [ 'https://google.com', 'https://github.com', 'https://stripe.com', ]; $result = $client->batch($urls, [ 'format' => 'png', 'fullPage' => true, ]); foreach ($result['results'] as $item) { echo "{$item['url']} -> {$item['filename']}\n"; }
Visual Diff
$result = $client->diff( 'https://example.com', 'https://example.org', ['width' => 1280, 'height' => 720] ); echo "Pages differ by {$result['percentage']}%\n"; file_put_contents('diff.png', $result['image']);
Advanced Options
$image = $client->screenshot('https://example.com', [ 'width' => 1280, 'height' => 720, 'fullPage' => true, 'format' => 'png', 'delay' => 2, 'darkMode' => true, 'deviceScaleFactor' => 2, 'customCss' => "body { font-family: 'Comic Sans MS' !important; }", 'customJs' => "document.querySelector('.popup').remove()", 'waitForSelector' => '.content-loaded', 'clickSelector' => '.accept-cookies', 'hideSelectors' => ['.ad-banner', '.newsletter-popup'], 'blockAds' => true, 'headers' => ['Authorization' => 'Bearer token'], 'cookies' => [ ['name' => 'session', 'value' => 'abc123', 'domain' => 'example.com'], ], 'geolocation' => ['latitude' => 40.7128, 'longitude' => -74.0060], 'timezone' => 'America/New_York', ]);
Error Handling
use ShotAPI\Client; use ShotAPI\ShotAPIException; $client = new Client('sk_your_api_key'); try { $image = $client->screenshot('https://example.com'); } catch (ShotAPIException $e) { if ($e->isAuthError()) { echo "Invalid API key\n"; } elseif ($e->isRateLimited()) { echo "Rate limit exceeded\n"; } elseif ($e->isFeatureNotAvailable()) { echo "Feature not available on your plan\n"; } else { echo "API error: " . $e->getMessage() . "\n"; } }
Configuration
// Custom base URL and timeout $client = new Client( 'sk_your_api_key', 'https://shotapi.net', // base URL 120 // timeout in seconds );
Laravel Integration
// config/services.php 'shotapi' => [ 'key' => env('SHOTAPI_KEY'), ], // App\Providers\AppServiceProvider.php public function register() { $this->app->singleton(\ShotAPI\Client::class, function () { return new \ShotAPI\Client(config('services.shotapi.key')); }); } // Usage in controller public function screenshot(Request $request) { $client = app(\ShotAPI\Client::class); $image = $client->screenshot($request->url); return response($image)->header('Content-Type', 'image/png'); }
Links
License
MIT License