Інтеграція Cloudinary для управління медіафайлами сайту

Наша компанія займається розробкою, підтримкою та обслуговуванням сайтів будь-якої складності. Від простих односторінкових сайтів до масштабних кластерних систем, побудованих на мікро сервісах. Досвід розробників підтверджено сертифікатами від вендорів.
Розробка та обслуговування будь-яких видів сайтів:
Інформаційні сайти або веб-програми
Сайти візитки, landing page, корпоративні сайти, онлайн каталоги, квіз, промо-сайти, блоги, ресурси новин, інформаційні портали, форуми, агрегатори
Сайти або веб-програми електронної комерції
Інтернет-магазини, B2B-портали, маркетплейси, онлайн-обмінники, кешбек-сайти, біржі, дропшиппінг-платформи, парсери товарів
Веб-програми для управління бізнес-процесами
CRM-системи, ERP-системи, корпоративні портали, системи управління виробництвом, парсери інформації
Сайти або веб-програми електронних послуг
Дошки оголошень, онлайн-школи, онлайн-кінотеатри, конструктори сайтів, портали надання електронних послуг, відеохостинги, тематичні портали

Це лише деякі з технічних типів сайтів, з якими ми працюємо, і кожен із них може мати свої специфічні особливості та функціональність, а також бути адаптованим під конкретні потреби та цілі клієнта.

Пропоновані послуги
Показано 1 з 1 послугУсі 2065 послуг
Інтеграція Cloudinary для управління медіафайлами сайту
Проста
від 1 робочого дня до 3 робочих днів
Часті питання
Наші компетенції:
Етапи розробки
Останні роботи
  • image_website-b2b-advance_0.png
    Розробка сайту компанії B2B ADVANCE
    1262
  • image_web-applications_feedme_466_0.webp
    Розробка веб-додатків для компанії FEEDME
    1171
  • image_websites_belfingroup_462_0.webp
    Розробка веб-сайту для компанії БЕЛФІНГРУП
    874
  • image_ecommerce_furnoro_435_0.webp
    Розробка інтернет магазину для компанії FURNORO
    1094
  • image_crm_enviok_479_0.webp
    Розробка веб-додатків для компанії Enviok
    831
  • image_bitrix-bitrix-24-1c_fixper_448_0.png
    Розробка веб-сайту для компанії ФІКСПЕР
    851

Інтеграція Cloudinary для управління медіафайлами веб-сайту

Cloudinary — облачний сервіс для зберігання, трансформації й доставки зображень і відео. Основна цінність — не просто CDN, а динамічні трансформації через URL: зміна розміру, формату, якості, обрізка, накладення водяних знаків прямо у параметрах запиту. Ніяких заготованих превью, одне зображення — всі потрібні розміри.

Підключення і конфігурація

Реєстрація на cloudinary.com, у дашборді — Cloud Name, API Key, API Secret.

composer require cloudinary-labs/cloudinary-laravel
CLOUDINARY_URL=cloudinary://API_KEY:API_SECRET@CLOUD_NAME
// config/cloudinary.php публікується через artisan vendor:publish

Завантаження файлів

use CloudinaryLabs\CloudinaryLaravel\Facades\Cloudinary;

// Завантаження зі збереженням public_id
$result = Cloudinary::upload($request->file('image')->getRealPath(), [
    'folder'    => 'products',
    'public_id' => 'product-' . $product->id,
    'overwrite' => true,
    'tags'      => ['product', 'catalog'],
]);

$publicId  = $result->getPublicId();   // products/product-123
$secureUrl = $result->getSecureUrl();  // https://res.cloudinary.com/...

У базі достатньо зберігати public_id — URL генерується динамічно при кожному зверненні. Зберігати URL не потрібно: він зміниться при смені домену або параметрів трансформації.

Динамічні трансформації через URL

Все управління зображенням — в URL:

https://res.cloudinary.com/CLOUD_NAME/image/upload/
  w_800,h_600,c_fill,g_auto,f_auto,q_auto/
  products/product-123

Параметри:

  • w_800,h_600 — ширина й висота
  • c_fill — режим обрізки (fill, fit, scale, crop, thumb та ін.)
  • g_auto — автоматичний вибір фокуса (AI-визначення головного об'єкту)
  • f_auto — автоматичний формат (WebP для Chrome, AVIF де підтримується, JPEG для решти)
  • q_auto — автоматична якість (Cloudinary підбирає оптимальну)

На PHP зручніше генерувати URL через SDK:

use Cloudinary\Cloudinary;
use Cloudinary\Transformation\Resize;
use Cloudinary\Transformation\Quality;
use Cloudinary\Transformation\Format;

$cloudinary = new Cloudinary();

$url = $cloudinary->image($publicId)
    ->resize(Resize::fill()->width(800)->height(600)->gravity('auto'))
    ->quality(Quality::auto())
    ->format(Format::auto())
    ->toUrl();

Адаптивні зображення

Для різних екранів генеруємо кілька розмірів:

function cloudinaryResponsive(string $publicId, array $widths = [400, 800, 1200]): string
{
    $cloudinary = new Cloudinary();
    $srcset = [];

    foreach ($widths as $w) {
        $url = $cloudinary->image($publicId)
            ->resize(Resize::scale()->width($w))
            ->format(Format::auto())
            ->quality(Quality::auto())
            ->toUrl();
        $srcset[] = "{$url} {$w}w";
    }

    return implode(', ', $srcset);
}
<img
  src="https://res.cloudinary.com/CLOUD/image/upload/w_800,f_auto,q_auto/products/123"
  srcset="{{ cloudinaryResponsive('products/product-123') }}"
  sizes="(max-width: 600px) 400px, (max-width: 1200px) 800px, 1200px"
  alt="..."
  loading="lazy"
>

Відео: автоматична оптимізація

$videoUrl = $cloudinary->video($publicId)
    ->resize(Resize::scale()->width(1280))
    ->quality(Quality::auto())
    ->format(Format::auto()) // mp4/webm за підтримкою браузера
    ->toUrl();

Для потокового відео Cloudinary генерує адаптивний бітрейт (ABR) при наявності відповідного плану.

Підписані URL для приватних файлів

Якщо файли не повинні бути публічно доступні:

$signedUrl = $cloudinary->image($publicId)
    ->signUrl(true)
    ->resize(Resize::scale()->width(800))
    ->toUrl();

Підписаний URL містить HMAC-підпис і може мати час життя — через параметр expires_at при генерації.

Видалення й управління ресурсами

// Видалення одного файлу
Cloudinary::destroy('products/product-123');

// Видалення за тегом (наприклад, всі зображення видаленого товара)
$cloudinary->adminApi()->deleteResourcesByTag('product-123');

Гуки завантаження: автоматична обробка

Cloudinary підтримує Incoming Transformations — трансформації, застосовані автоматично при завантаженні. Наприклад, автоматичне видалення фону для каталожних фото:

Cloudinary::upload($path, [
    'eager' => [
        ['effect' => 'background_removal', 'format' => 'png'],
        ['width' => 800, 'height' => 800, 'crop' => 'fill', 'format' => 'webp'],
    ],
    'eager_async' => true,
]);

Після завантаження Cloudinary асинхронно застосовує трансформації й може сповістити вебхуком про готовність.

Терміни й що входить

Базове підключення SDK, завантаження файлів, генерація динамічних URL: 2–4 години. Повний кейс з адаптивними зображеннями, автоформатом, управлінням через медіатеку й видаленням при видаленні контенту з CMS — 1 робочий день.