uk
Feedback
Библиотека PHP программиста 👨🏼‍💻👩‍💻

Библиотека PHP программиста 👨🏼‍💻👩‍💻

Відкрити в Telegram

Полезные материалы по PHP, Laravel, Symfony, CodeIgniter, CakePHP, Phalcon По всем вопросам @evgenycarter

Показати більше
2 081
Підписники
-424 години
-97 днів
-1830 день
Залучення підписників
червень '26
червень '26
+4
в 0 каналах
травень '26
+11
в 0 каналах
Get PRO
квітень '26
+15
в 0 каналах
Get PRO
березень '26
+12
в 0 каналах
Get PRO
лютий '26
+20
в 0 каналах
Get PRO
січень '26
+29
в 0 каналах
Get PRO
грудень '25
+17
в 0 каналах
Get PRO
листопад '25
+35
в 32 каналах
Get PRO
жовтень '25
+36
в 0 каналах
Get PRO
вересень '25
+45
в 36 каналах
Get PRO
серпень '25
+31
в 0 каналах
Get PRO
липень '25
+27
в 26 каналах
Get PRO
червень '25
+47
в 20 каналах
Get PRO
травень '25
+47
в 43 каналах
Get PRO
квітень '25
+59
в 37 каналах
Get PRO
березень '25
+46
в 38 каналах
Get PRO
лютий '25
+62
в 32 каналах
Get PRO
січень '25
+50
в 34 каналах
Get PRO
грудень '24
+42
в 35 каналах
Get PRO
листопад '24
+47
в 33 каналах
Get PRO
жовтень '24
+51
в 30 каналах
Get PRO
вересень '24
+117
в 29 каналах
Get PRO
серпень '24
+69
в 18 каналах
Get PRO
липень '24
+42
в 1 каналах
Get PRO
червень '24
+56
в 24 каналах
Get PRO
травень '24
+67
в 19 каналах
Get PRO
квітень '24
+51
в 1 каналах
Get PRO
березень '24
+81
в 21 каналах
Get PRO
лютий '24
+75
в 19 каналах
Get PRO
січень '24
+102
в 24 каналах
Get PRO
грудень '23
+82
в 24 каналах
Get PRO
листопад '23
+66
в 17 каналах
Get PRO
жовтень '23
+106
в 18 каналах
Get PRO
вересень '23
+69
в 0 каналах
Get PRO
серпень '23
+66
в 0 каналах
Get PRO
липень '23
+60
в 0 каналах
Get PRO
червень '23
+76
в 0 каналах
Get PRO
травень '23
+113
в 0 каналах
Get PRO
квітень '23
+66
в 0 каналах
Get PRO
березень '23
+20
в 0 каналах
Get PRO
лютий '23
+50
в 0 каналах
Get PRO
січень '23
+108
в 0 каналах
Get PRO
грудень '22
+106
в 0 каналах
Get PRO
листопад '22
+73
в 0 каналах
Get PRO
жовтень '22
+90
в 0 каналах
Get PRO
вересень '22
+302
в 0 каналах
Get PRO
серпень '22
+341
в 0 каналах
Get PRO
липень '22
+3 386
в 0 каналах
Дата
Залучення підписників
Згадування
Канали
24 червня0
23 червня0
22 червня+1
21 червня0
20 червня0
19 червня0
18 червня0
17 червня0
16 червня0
15 червня0
14 червня0
13 червня0
12 червня0
11 червня+1
10 червня0
09 червня0
08 червня0
07 червня0
06 червня0
05 червня0
04 червня+2
03 червня0
02 червня0
01 червня0
Дописи каналу
Laravel lazy() против get() Знаешь ли ты… что можно обрабатывать большие объёмы данных из базы с помощью lazy() — это гораздо
Laravel lazy() против get() Знаешь ли ты… что можно обрабатывать большие объёмы данных из базы с помощью lazy() — это гораздо эффективнее по памяти, чем get(). 📲 Мы в MAX 👉 @php_lib

2
📲 Мы в MAX 👉 @php_lib
📲 Мы в MAX 👉 @php_lib
210
3
Сегодня я покажу вам, как быстро разрулить хаос в проекте с кастомным фреймворком, где нет нормального логирования. Ситуация:
Сегодня я покажу вам, как быстро разрулить хаос в проекте с кастомным фреймворком, где нет нормального логирования. Ситуация: клиент дал старый проект, ошибок — куча, но логов нет вообще. В коде try-catch, а в catch — пусто. Что делать? Вот мой быстрый чеклист, который спасал не раз: 1. Глобальный обработчик ошибок и исключений set_error_handler(function ($errno, $errstr, $errfile, $errline) { error_log("[PHP ERROR] $errstr in $errfile:$errline"); return false; }); set_exception_handler(function (Throwable $e) { error_log("[UNCAUGHT EXCEPTION] " . $e->getMessage() . ' in ' . $e->getFile() . ':' . $e->getLine()); }); Добавил в index.php, и уже вижу, что именно валится. 2. Простой логгер на каждый чих Создал файл logger.php: function log_debug($msg) { file_put_contents(__DIR__.'/debug.log', date('[Y-m-d H:i:s] ') . $msg . PHP_EOL, FILE_APPEND); } В нужных местах пишу log_debug('что-то случилось');. Дёшево и сердито, зато работает. 3. Прокинул заголовки и запросы В самых первых строках запроса: log_debug("REQUEST: " . $_SERVER['REQUEST_METHOD'] . ' ' . $_SERVER['REQUEST_URI']); log_debug("HEADERS: " . json_encode(getallheaders())); log_debug("POST: " . json_encode($_POST)); Теперь видно, с чем именно клиент ломает мой старый код. Не всегда есть время подтягивать Monolog и делать всё красиво. Иногда нужно быстро найти, где горит — и потушить. А уже потом наводить красоту. А вы как действуете в таких ситуациях? Есть свои приёмы? 📲 Мы в MAX 👉 @php_lib
303
4
💡Совет по Laravel Знаешь ли ты, что можно выбрасывать исключения условно всего в одну строку с помощью throw_if() — идеально
💡Совет по Laravel Знаешь ли ты, что можно выбрасывать исключения условно всего в одну строку с помощью throw_if() — идеально для лаконичного кода в контроллерах и сервисах. 📲 Мы в MAX 👉 @php_lib
366
5
Сегодня расскажу вам про одну простую, но очень полезную привычку для любого PHP-разработчика — вести чек-листы по задачам пр
Сегодня расскажу вам про одну простую, но очень полезную привычку для любого PHP-разработчика — вести чек-листы по задачам прямо в коде. Когда проект становится чуть больше "визитки", начинают скапливаться мелкие задачи: что-то подправить, где-то доделать, что-то не забыть протестировать. В итоге куча мыслей крутится в голове, а шанс что-то упустить растёт. Как я с этим борюсь? Я просто добавляю короткие TODO-комментарии в нужных местах кода. Например: // TODO: Проверить валидацию email после изменений // TODO: Перевести этот блок на отдельный сервис Каждый раз перед коммитом быстро пробегаюсь по проекту поиском по "TODO" — и вижу все свои маленькие хвосты. А когда задач становится много, использую расширения для IDE (например, "TODO Highlight" в VSCode) — и визуально сразу видно все невыполненные задачи. Почему это работает: * Не надо держать всё в голове. * Любой разработчик быстро вникает в текущие проблемы кода. * Легче планировать рефакторинг. * Сложно забыть про важную доработку. Советую прямо сегодня попробовать добавить пару своих TODO в код. Дай знать, пользуешься ли ты таким приёмом или предпочитаешь другие методы? Пиши в комментариях! 📲 Мы в MAX 👉 @php_lib
482
6
Сегодня я хочу поделиться приёмом, который сильно упростил мне жизнь при отладке в PHP. 🛠️ Как дебажить сложные объекты в La
Сегодня я хочу поделиться приёмом, который сильно упростил мне жизнь при отладке в PHP. 🛠️ Как дебажить сложные объекты в Laravel удобно? Когда ты работаешь с коллекциями, запросами или вложенными структурами, dd() или dump() часто захламляют вывод. Но есть куда более изящный способ: logger($someObject); Этот метод не прерывает выполнение скрипта, в отличие от dd(), и пишет в storage/logs/laravel.log. И вот тут начинается магия: 📌 Хочешь, чтобы лог был читаемым? Добавь кастомный формат: logger()->info('User data', [$user->toArray()]); Или ещё лучше — используй Laravel-помощники вроде tap(): tap($response, fn($res) => logger($res->toArray())); 💡 Это особенно удобно, когда ты хочешь просто взглянуть на данные, не роняя приложение. 🔥 Бонус: в .env можно задать LOG_LEVEL=debug, и ты увидишь всё, даже что делает сам Laravel под капотом. Такие мелочи превращают обычную отладку в аккуратный контроль за происходящим в приложении. А как ты обычно дебажишь в Laravel — через dd() или есть свои фишки? 📲 Мы в MAX 👉 @php_lib
386
7
Сегодня я покажу вам, как безопасно работать с пользовательским вводом в PHP — тема старая, но до сих пор частая причина уязв
Сегодня я покажу вам, как безопасно работать с пользовательским вводом в PHP — тема старая, но до сих пор частая причина уязвимостей. Часто вижу в коде что-то вроде: $id = $_GET['id']; $query = "SELECT * FROM users WHERE id = $id"; Если вы всё ещё так делаете — пора остановиться. Это прямое приглашение для SQL-инъекций. Даже если вы думаете "ну я же intval() применяю", это не решение. Правильный подход — использовать подготовленные выражения (prepared statements). Пример на PDO: $id = $_GET['id']; $stmt = $pdo->prepare("SELECT * FROM users WHERE id = :id"); $stmt->execute(['id' => $id]); $user = $stmt->fetch(); Если вы используете mysqli, там тоже есть prepare() — не игнорируйте его. Никогда не вставляйте переменные напрямую в SQL-запросы. Также стоит помнить: фильтрация ≠ экранирование, и экранирование ≠ защита. Настоящая защита — это изоляция данных от SQL с помощью prepare(). ✍️ А как вы валидируете и обрабатываете пользовательские данные? Используете ли какую-то свою обёртку или ORM? Поделитесь в комментариях. 📲 Мы в MAX 👉 @php_lib
450
8
🚀 Подборка полезных IT каналов в Max Системное администрирование, DevOps 📌 https://max.ru/i_odmin Все для системного администратора https://max.ru/bash_srv Bash Советы https://max.ru/sysadminof Книги для админов, полезные материалы https://max.ru/i_odmin_book Библиотека Системного Администратора https://max.ru/i_devops DevOps: Пишем о Docker, Kubernetes и др. https://max.ru/tipsysdmin Типичный Сисадмин Excel лайфхак 📌 https://t.me/Excel_lifehack Excel лайфхак 1C разработка 📌 https://max.ru/odin1c_rus Cтатьи, курсы, советы, шаблоны кода 1С Программирование C++📌 https://max.ru/cpp_lib Библиотека C/C++ разработчика Программирование Go📌 https://max.ru/golang_lib Библиотека Go (Golang) разработчика Программирование React📌 https://max.ru/react_lib React Программирование Python 📌 https://max.ru/python_of Python академия. https://max.ru/BookPython Библиотека Python разработчика Java разработка 📌 https://max.ru/bookjava Библиотека Java разработчика GitHub Сообщество 📌 https://max.ru/githublib Интересное из GitHub Базы данных (Data Base) 📌 https://max.ru/database_info Все про базы данных Фронтенд разработка 📌 https://max.ru/frontend_1 Подборки для frontend разработчиков Библиотеки 📌 https://max.ru/programmist_of Книги по программированию https://max.ru/proglb Библиотека программиста https://max.ru/bfbook Книги для программистов Программирование 📌 https://max.ru/bookflow Лекции, видеоуроки, доклады с IT конференций https://max.ru/itmozg Программисты, дизайнеры, новости из мира IT https://max.ru/php_lib Библиотека PHP программиста 👨🏼‍💻👩‍💻 Шутки программистов 📌 https://max.ru/itumor Шутки программистов Защита, взлом, безопасность 📌 https://max.ru/thehaking Канал о кибербезопасности https://max.ru/xakkep_1 Хакер Free Книги, статьи для дизайнеров 📌 https://max.ru/odesigners Статьи, книги для дизайнеров Математика 📌 https://max.ru/Pomatematike Канал по математике https://max.ru/phismat_1 Обучающие видео, книги по Физике и Математике Вакансии 📌 https://max.ru/progjob Вакансии в IT Мир технологий 📌 https://max.ru/mir_teh Канал для любознательных Бонус 📌 https://max.ru/piterspb_78 Свежие новости Санкт-Петербурга https://max.ru/mockva_life Свежие новости Москвы https://max.ru/piterspb Питер Новости: Санкт-Петербург / СПБ / ДТП
359
9
Сегодня я покажу вам, как быстро и удобно организовать автозагрузку классов в PHP без использования Composer. Мы все любим Co
Сегодня я покажу вам, как быстро и удобно организовать автозагрузку классов в PHP без использования Composer. Мы все любим Composer, но бывают ситуации, когда он просто неуместен — например, в небольшом проекте, скрипте или легаси-коде, где Composer не использовался изначально. В таких случаях можно сделать свою простую, но эффективную автозагрузку. Вот базовый пример: spl_autoload_register(function ($class) { $baseDir = __DIR__ . '/src/'; $classPath = str_replace('\\', '/', $class) . '.php'; $file = $baseDir . $classPath; if (file_exists($file)) { require $file; } }); Что здесь происходит: - spl_autoload_register регистрирует анонимную функцию, которая будет вызываться при попытке использовать неизвестный класс. - Класс App\Services\MailService превратится в путь src/App/Services/MailService.php - Если файл существует — он подключается. Это суперудобный способ структурировать код и избавиться от бесконечных require. Если хочется чуть больше гибкости — можно добавить поддержку нескольких базовых директорий, логирование ошибок или даже кэширование найденных путей. 📲 Мы в MAX 👉 @php_lib
422
10
Сегодня хочу рассказать вам про одну ошибку, которую я часто встречаю у начинающих PHP-разработчиков — неправильную работу с
Сегодня хочу рассказать вам про одну ошибку, которую я часто встречаю у начинающих PHP-разработчиков — неправильную работу с датами и временем. Когда вы используете функции вроде date(), strtotime(), time() напрямую без явной установки временной зоны (timezone), ваш код может начать вести себя непредсказуемо. Особенно если ваш проект запущен на серверах в разных регионах. Чтобы избежать проблем: - Всегда задавайте временную зону явно через date_default_timezone_set('Your/Timezone'); в начале вашего приложения. - Или лучше используйте объекты DateTime и DateTimeZone, они гораздо удобнее для работы с временными зонами и манипуляциями с датами. Пример хорошего подхода: $date = new DateTime('now', new DateTimeZone('Europe/Moscow')); echo $date->format('Y-m-d H:i:s'); И еще одна рекомендация — всегда храните даты в базе данных в формате UTC, а уже при выводе преобразовывайте их в нужную временную зону для пользователя. Небольшая дисциплина в работе с временем сэкономит вам кучу нервов в будущем. Проверено на реальных проектах! 📲 Мы в MAX 👉 @php_lib
417
11
Сегодня я хочу показать вам простой, но очень полезный приём для работы с массивами в PHP — использование функции array_column(). Очень часто бывает задача: из многомерного массива "вытащить" только один столбец данных. Например, у вас есть массив пользователей: $users = [ ['id' => 1, 'name' => 'Иван', 'email' => 'ivan@example.com'], ['id' => 2, 'name' => 'Ольга', 'email' => 'olga@example.com'], ['id' => 3, 'name' => 'Павел', 'email' => 'pavel@example.com'], ]; И нужно получить только список всех email'ов. Многие делают это через foreach, но есть более элегантное решение: $emails = array_column($users, 'email'); Результат будет таким: [ 'ivan@example.com', 'olga@example.com', 'pavel@example.com' ] А ещё array_column() позволяет указать третий параметр — ключ массива. Например, сделать email по id: $emailsById = array_column($users, 'email', 'id'); И тогда получится: [ 1 => 'ivan@example.com', 2 => 'olga@example.com', 3 => 'pavel@example.com' ] Это удобный способ быстрого преобразования данных без лишнего кода. Пользуетесь ли вы array_column() в своих проектах? Или предпочитаете что-то другое? Напишите в комментариях! 📲 Мы в MAX 👉 @php_lib
435
12
Сегодня я покажу вам простой способ, как разрулить хардкорный баг с session_start() в PHP. Недавно один подписчик столкнулся с ситуацией: скрипт падает с ошибкой "Cannot send session cache limiter - headers already sent". Думаю, каждый второй PHP-разработчик хотя бы раз в жизни это видел. Разбираемся. 💥 Причина Ошибка возникает, когда session_start() вызывается после того, как браузеру уже отправлены заголовки. В PHP это означает — где-то до session_start() был echo, пробел вне тегов <?php ?>, или даже var_dump() для отладки. Любой вывод в браузер = PHP уже отправил заголовки. А session_start() хочет их изменить — и ловим ошибку. ✅ Как лечить 1. Ищем вывод до session_start() - Проверь, нет ли echo, print, отладочных функций или лишних символов до вызова session_start(). - Включи буферизацию ob_start() в начале скрипта — поможет временно «глотать» вывод: ob_start(); session_start(); Но это костыль. Лучше всё же вычистить лишний вывод. 2. Идеальная структура файла <?php // Никакого вывода до этого места! session_start(); // Весь остальной код ?> 3. Ищи BOM Иногда редакторы типа Notepad++ добавляют невидимый символ BOM в начало файла. Он тоже считается выводом. Решается сохранением файла в UTF-8 без BOM. 🛠 Мой способ отладки Когда всё выглядит правильно, но ошибка всё равно есть: - Создай новый чистый файл, вставь туда session_start() — если работает, значит проблема в другом коде. - Используй headers_sent(): if (headers_sent($file, $line)) { echo "Вывод уже начат в $file на строке $line"; } Это сэкономило мне кучу времени при отладке старых легаси-проектов. 📲 Мы в MAX 👉 @php_lib
466
13
Сегодня я покажу вам, как удобно логировать в Laravel, не засоряя код и не превращая проект в болото из Log::info() на каждом шагу. 💡 Используем каналы логирования правильно Laravel предоставляет мощную систему логирования на базе Monolog. Но часто мы ограничиваемся дефолтным логом. А зря. Например, создаём отдельный канал для логов оплаты: // config/logging.php 'channels' => [ 'payment' => [ 'driver' => 'single', 'path' => storage_path('logs/payment.log'), 'level' => 'info', ], ], Теперь в нужном месте можно писать: Log::channel('payment')->info('Платёж прошёл', ['user_id' => $user->id, 'amount' => $amount]); И всё — никакой путаницы. В laravel.log остаётся только то, что важно для всего проекта, а логи оплаты — отдельно. Можно и в телеграм скидывать, если настроить webhook. 👀 Бонус: helper-функция Чтобы писать меньше: if (!function_exists('payment_log')) { function payment_log($message, array $context = []) { \Log::channel('payment')->info($message, $context); } } Теперь вызываем везде просто payment_log('Платёж принят'). Пишите в комментах, какие каналы логирования вы используете и куда пишете — в файл, телегу или Sentry? 📲 Мы в MAX 👉 @php_lib
426
14
🧑‍💻 Приглашаем на открытый урок курса «PHP-разработчик. Продвинутый уровень» 19 мая в 20:00 — Работа с очередями в Laravel:
🧑‍💻 Приглашаем на открытый урок курса «PHP-разработчик. Продвинутый уровень» 19 мая в 20:00 — Работа с очередями в Laravel: от настройки до решения типичных проблем Разберём, как очереди помогают ускорить приложение и вынести тяжёлые задачи в фон без потери стабильности. Обсудим настройку и обработку задач, типичные ошибки, повторы при сбоях, защиту от дублирования и мониторинг выполнения. Вы поймёте, как работают фоновые процессы в Laravel, научитесь правильно настраивать очереди и делать приложение быстрее и надёжнее. 🚀Открытый урок проходит в преддверии старта курса «PHP-разработчик. Продвинутый уровень» 19 мая в 20:00 МСК. Регистрация: https://vk.cc/cXMQc2 Реклама. ООО «Отус онлайн-образование», ОГРН 1177746618576, www.otus.ru
475
15
Сегодня я покажу вам простой, но мощный способ, как ускорить отладку в Laravel при работе с большим количеством логики в контроллерах и сервисах. 🔍 Ловим баги быстрее с помощью ray() от Spatie Обычно мы используем dd() или dump() в Laravel, чтобы посмотреть, что творится с переменными. Но как только проект становится крупнее — эти методы начинают мешать, особенно когда нужно отслеживать несколько значений в разных местах. Спасает Ray — инструмент от Spatie, который интегрируется с Laravel и выводит отладочную информацию в отдельное десктопное приложение. Пример: ray($user); ray($order)->blue(); ray()->showQueries(); Ты можешь: - выводить переменные без прерывания скрипта; - смотреть SQL-запросы в реальном времени; - использовать цветовые метки, чтобы различать вывод из разных участков кода. ⚙️ Установка composer require spatie/laravel-ray --dev И по желанию установить десктоп-приложение с сайта Spatie. В config/ray.php можно кастомизировать поведение: включать Ray только на dev-среде, логировать только определённые запросы и т.д. 🧠 Совет от себя Ray особенно хорошо заходит, когда работаешь в команде — ты можешь добавить временный ray()-лог, не ломая исполнение и не мешая другим. Пробовали Ray? Или у вас есть свои инструменты для отладки — может, кастомные макросы или трейты? Делитесь в комментах 👇 📲 Мы в MAX 👉 @php_lib
461
16
.🛠 Как логировать SQL-запросы только при ошибках Часто сталкиваюсь с ситуацией: ошибка 500 в проде, а что именно пошло не так — неясно. Особенно если это была ошибка в SQL-запросе. Логировать все SQL-запросы — слишком жирно и шумно. Но логировать только при исключениях — вот это огонь! 🔍 Решение Добавьте следующий сниппет в AppServiceProvider: use Illuminate\Support\Facades\DB; use Illuminate\Support\Facades\Log; public function boot() { DB::listen(function ($query) { if (app()->bound('exception.logged')) { Log::channel('sql')->debug($query->sql, $query->bindings); } }); app()->singleton('exception.logged', function () { return true; }); app()->error(function (\Throwable $e) { app()->instance('exception.logged', true); }); } 🔐 Пояснение - При каждом SQL-запросе мы проверяем, был ли в этом запросе выброшен exception. - Если да — логируем SQL. - Используем отдельный лог-канал sql, чтобы не засорять основной laravel.log. 👉 Создайте в config/logging.php канал sql, направьте его в отдельный файл, например storage/logs/sql.log. Теперь, если в продакшене будет падение — вы увидите какой SQL-запрос был выполнен перед ошибкой. Это невероятно ускоряет диагностику багов. 📲 Мы в MAX 👉 @php_lib
544
17
Сегодня я покажу вам, как я упростил настройку и запуск Laravel-проектов с помощью кастомной Make-команды. Когда ты постоянно работаешь с Laravel, мелочи вроде php artisan migrate, npm run dev, php artisan serve, php artisan key:generate превращаются в рутину. А если ещё и несколько проектов — путаницы не избежать. Я решил: хватит. Создал для себя простую Makefile-команду, которая за секунды поднимает проект в нужной последовательности. Вот пример: up: @cp .env.example .env || true @php artisan key:generate @composer install @npm install @php artisan migrate @php artisan db:seed @npm run dev @php artisan serve Теперь я просто пишу make up — и Laravel взлетает 🚀 Можно добавить другие команды: make test, make down, make fresh, make lint, и каждый проект становится управляемым по единому сценарию. Это экономит часы за месяц. 💡 Совет: обязательно ставь @ перед командами — так терминал не будет засорён выводом самих строк Makefile. 📲 Мы в MAX 👉 @php_lib
545
18
Сегодня покажу вам простой, но очень удобный приём, который помогает наводить порядок в больших PHP-проектах — использование кастомных коллекций вместо массивов. Если вы когда-нибудь передавали в методы или возвращали из них массивы с объектами, то наверняка сталкивались с ситуацией, когда непонятно, что в массиве лежит. А потом кто-нибудь передал туда строку или null — и привет, баги. Я стал использовать свои классы коллекций. Простой пример: class UserCollection { /** @var User[] */ private array $users = []; public function __construct(array $users = []) { foreach ($users as $user) { $this->add($user); } } public function add(User $user): void { $this->users[] = $user; } public function all(): array { return $this->users; } public function filterByActive(): self { return new self(array_filter($this->users, fn(User $u) => $u->isActive())); } // и так далее } Теперь везде, где раньше был User[], я работаю с UserCollection. Это сразу даёт: - типизацию (и защиту от мусора), - автодополнение в IDE, - методы прямо в коллекции (например, filterByActive, sortByName, first() и т.д.), - чище и понятнее сигнатуры методов. Это похоже на коллекции из Laravel, но я использую это везде, даже в маленьких проектах без фреймворков. Такие объекты делают код чище, устойчивее и легче читаемым. Попробуйте в одном из ваших проектов заменить массивы объектов на такие коллекции — и вы удивитесь, как стало лучше. 📲 Мы в MAX 👉 @php_lib
0
19
🚀 Подборка полезных IT каналов в Max Системное администрирование, DevOps 📌 https://max.ru/i_odmin Все для системного администратора https://max.ru/bash_srv Bash Советы https://max.ru/sysadminof Книги для админов, полезные материалы https://max.ru/i_odmin_book Библиотека Системного Администратора https://max.ru/i_devops DevOps: Пишем о Docker, Kubernetes и др. https://max.ru/tipsysdmin Типичный Сисадмин 1C разработка 📌 https://max.ru/odin1c_rus Cтатьи, курсы, советы, шаблоны кода 1С Программирование C++📌 https://max.ru/cpp_lib Библиотека C/C++ разработчика Программирование Go📌 https://max.ru/golang_lib Библиотека Go (Golang) разработчика Программирование React📌 https://max.ru/react_lib React Программирование Python 📌 https://max.ru/python_of Python академия. https://max.ru/BookPython Библиотека Python разработчика Java разработка 📌 https://max.ru/bookjava Библиотека Java разработчика GitHub Сообщество 📌 https://max.ru/githublib Интересное из GitHub Базы данных (Data Base) 📌 https://max.ru/database_info Все про базы данных Фронтенд разработка 📌 https://max.ru/frontend_1 Подборки для frontend разработчиков Библиотеки 📌 https://max.ru/programmist_of Книги по программированию https://max.ru/proglb Библиотека программиста https://max.ru/bfbook Книги для программистов Программирование 📌 https://max.ru/bookflow Лекции, видеоуроки, доклады с IT конференций https://max.ru/itmozg Программисты, дизайнеры, новости из мира IT https://max.ru/php_lib Библиотека PHP программиста 👨🏼‍💻👩‍💻 Шутки программистов 📌 https://max.ru/itumor Шутки программистов Защита, взлом, безопасность 📌 https://max.ru/thehaking Канал о кибербезопасности https://max.ru/xakkep_1 Хакер Free Книги, статьи для дизайнеров 📌 https://max.ru/odesigners Статьи, книги для дизайнеров Математика 📌 https://max.ru/Pomatematike Канал по математике https://max.ru/phismat_1 Обучающие видео, книги по Физике и Математике Вакансии 📌 https://max.ru/progjob Вакансии в IT Мир технологий 📌 https://max.ru/mir_teh Канал для любознательных Бонус 📌 https://max.ru/piterspb_78 Свежие новости Санкт-Петербурга https://max.ru/mockva_life Свежие новости Москвы
0
20
Сегодня покажу вам простую, но мощную технику, которая может прокачать ваш PHP-код — Value Object вместо простых типов. Мы часто передаём параметры как string, int, array. Всё просто и понятно. Но как только бизнес-логика усложняется — типы начинают нас подводить. Допустим, у вас есть метод: function sendSms(string $phoneNumber, string $message): void А теперь скажите честно — сколько раз вы ловили себя на том, что phoneNumber передаётся в неправильном формате? Или вовсе пустым? Или из другой страны, а вы это не предусмотрели? Вот тут и приходят на помощь Value Object'ы: final class PhoneNumber { public function __construct(private string $number) { if (!preg_match('/^\+7\d{10}$/', $number)) { throw new InvalidArgumentException('Invalid phone number'); } } public function value(): string { return $this->number; } } Теперь ваш метод будет выглядеть так: function sendSms(PhoneNumber $phoneNumber, Message $message): void Что мы получаем: - Валидность данных гарантируется на этапе создания объекта. - Код становится самодокументируемым — не нужно читать описание, чтобы понять, что именно сюда передаётся. - IDE и статическая проверка типа не дадут случайно передать email вместо phone. Да, это чуть больше кода. Но это тот случай, когда "больше" — значит надёжнее. 📲 Мы в MAX 👉 @php_lib
0