legich13 / laravel-url-shortener
A Laravel package for URL shortening (SOLID‑compliant)
1.0.0
2025-04-17 13:09 UTC
Requires
- php: >=8.0
- illuminate/support: ^8.0|^9.0|^10.0
Requires (Dev)
- orchestra/testbench: ^6.0|^7.0|^8.0
- phpunit/phpunit: ^9.0|^10.0
This package is auto-updated.
Last update: 2026-04-17 23:14:45 UTC
README
SOLID-принципы в действии: простой и гибкий пакет для сокращения URL в Laravel.
Установка
Установите пакет через Composer:
composer require legich13/laravel-url-shortener
Публикация файлов
Опубликуйте конфигурацию и миграции:
php artisan vendor:publish --provider="Vendor\UrlShortener\UrlShortenerServiceProvider" --tag="config" php artisan vendor:publish --provider="Vendor\UrlShortener\UrlShortenerServiceProvider" --tag="migrations"
Выполните миграции:
php artisan migrate
Использование
Сокращение URL с помощью фасада
use Vendor\UrlShortener\Facades\UrlShortener; // Сократить URL $code = UrlShortener::shorten('https://example.com/long-path'); // Получить полную короткую ссылку $shortUrl = url(config('url-shortener.route_prefix') . '/' . $code);
Использование в контроллере
namespace App\Http\Controllers; use Illuminate\Http\Request; use Vendor\UrlShortener\Services\UrlShortenerService; class UrlController extends Controller { protected $urlShortener; public function __construct(UrlShortenerService $urlShortener) { $this->urlShortener = $urlShortener; } public function shorten(Request $request) { $validated = $request->validate([ 'url' => 'required|url' ]); $code = $this->urlShortener->shorten($validated['url']); $shortUrl = url(config('url-shortener.route_prefix') . '/' . $code); return response()->json([ 'original_url' => $validated['url'], 'short_code' => $code, 'short_url' => $shortUrl ]); } public function redirect($code) { $longUrl = $this->urlShortener->expand($code); if (!$longUrl) { abort(404, 'Короткая ссылка не найдена'); } // Увеличиваем счетчик переходов $this->urlShortener->incrementClicks($code); // Перенаправляем на оригинальный URL return redirect()->away($longUrl); } }
Регистрация собственных маршрутов
Если вы отключили встроенные маршруты пакета ('enable_routes' => false), добавьте собственные в routes/web.php:
Route::post('urls/shorten', [App\Http\Controllers\UrlController::class, 'shorten'])->name('urls.shorten'); Route::get('u/{code}', [App\Http\Controllers\UrlController::class, 'redirect'])->name('urls.redirect');
Получение длинного URL из кода
$longUrl = UrlShortener::expand($code);
Подсчет переходов
Счетчик переходов увеличивается автоматически при каждом переходе или вручную:
UrlShortener::incrementClicks($code);
Настройка
Вы можете настроить пакет в файле config/url-shortener.php:
return [ // Имя таблицы для хранения 'table' => 'shortened_urls', // Включить встроенные маршруты пакета 'enable_routes' => true, // Префикс для всех коротких ссылок (можно пустым) 'route_prefix' => '', // Путь для редиректа (например, '/go/{code}') 'redirect_path' => '/{code}', ];
Тестирование
composer test
SOLID-принципы
Пакет разработан в соответствии с принципами SOLID:
- S - Single Responsibility Principle: каждый класс имеет одну ответственность
- O - Open/Closed Principle: расширение без модификации через интерфейсы
- L - Liskov Substitution Principle: взаимозаменяемость реализаций через интерфейсы
- I - Interface Segregation Principle: интерфейсы с минимальным набором методов
- D - Dependency Inversion Principle: зависимость от абстракций, а не от конкретных реализаций
License
The MIT License (MIT). См. License File для дополнительной информации.