php-tokio — Используйте любую асинхронную библиотеку Rust в PHP
Эта библиотека позволяет вам использовать любую асинхронную библиотеку Rust внутри PHP в асинхронном режиме.
Она полностью интегрирована с revolt: это обеспечивает полную совместимость с amphp , PSL и responsephp.
🔗 Github
#инструменты
Эта библиотека позволяет вам использовать любую асинхронную библиотеку Rust внутри PHP в асинхронном режиме.
Она полностью интегрирована с revolt: это обеспечивает полную совместимость с amphp , PSL и responsephp.
🔗 Github
#инструменты
Продолжаем рассказывать про полезные фишки шторма для начинающих. Вот подборка наиболее полезных сочетаний для редактирования:
🔸 Ctrl + D: дублирование текущей строки или выделенного блока.
🔸 Ctrl + Y: удаление строки под курсором.
🔸 Ctrl + Shift + J: объединение выделенных строк в одну, что упрощает форматирование массивов и HTML-тегов.
🔸 Ctrl + Alt + L: переформатирование кода в соответствии с настройками оформления.
Библиотека пхпшника #буст
Please open Telegram to view this post
VIEW IN TELEGRAM
Обеспечение надежности JSON из LLM-ответов в PHP
Эта статья рассказывает о библиотеке LLM-JSON-Cleaner, которая помогает разработчикам работать с JSON-ответами от больших языковых моделей (LLM). Если вы когда-нибудь взаимодействовали с LLM API, то наверняка сталкивались с ситуацией, когда вместо чистого JSON приходят ответы, содержащие дополнительный текст — приветствия, комментарии, пояснения. Даже если четко задать модели формат, она все равно может выдать неидеальный JSON.
Вот тут и пригодится LLM-JSON-Cleaner. Она решает две основные задачи: извлекает JSON из ответов LLM, удаляя весь ненужный текст, и проверяет, соответствует ли этот JSON заданной схеме.
Установить ее очень просто — достаточно выполнить команду
👉 Читать статью
Эта статья рассказывает о библиотеке LLM-JSON-Cleaner, которая помогает разработчикам работать с JSON-ответами от больших языковых моделей (LLM). Если вы когда-нибудь взаимодействовали с LLM API, то наверняка сталкивались с ситуацией, когда вместо чистого JSON приходят ответы, содержащие дополнительный текст — приветствия, комментарии, пояснения. Даже если четко задать модели формат, она все равно может выдать неидеальный JSON.
Вот тут и пригодится LLM-JSON-Cleaner. Она решает две основные задачи: извлекает JSON из ответов LLM, удаляя весь ненужный текст, и проверяет, соответствует ли этот JSON заданной схеме.
Установить ее очень просто — достаточно выполнить команду
composer require edgaras/llm-json-cleaner
. После этого можно сразу начинать использовать.👉 Читать статью
🔥 Ребус: проверяем вашу смекалку
Сможете угадать без гугла?
Ответ пишите в комментах 👇
Библиотека пхпшника #междусобойчик
Сможете угадать без гугла?
Ответ пишите в комментах 👇
Библиотека пхпшника #междусобойчик
🔎 Laravel 12.2: Введение пользовательских стартовых наборов
Команда Laravel выпустила версию 12.2.0, включающую метод
🔎 Релизы PHP 8.2.28 и PHP 8.1.32
Команда разработчиков PHP объявила о немедленной доступности версий PHP 8.2.28 и PHP 8.1.32. Эти обновления являются релизами безопасности, и всем пользователям рекомендуется обновиться до этих версий.
🔎 Неделя Symfony #950 (10–16 марта 2025 года)
На этой неделе в предстоящей версии Symfony 7.3 обновлены ленивые сервисы для использования нативных ленивых объектов PHP и добавлена возможность определения глобальных параметров перевода. В существующих версиях Symfony исправлена поддержка хуков PHP 8.4 и асимметричной видимости в
Команда Laravel выпустила версию 12.2.0, включающую метод
ddBody()
для тестирования ответов, поддержку одиночной модели через HasManyThrough
, контекстные ключи для методов increment
и decrement
, а также возможность создания пользовательских стартовых наборов для React, Vue и Livewire. 🔎 Релизы PHP 8.2.28 и PHP 8.1.32
Команда разработчиков PHP объявила о немедленной доступности версий PHP 8.2.28 и PHP 8.1.32. Эти обновления являются релизами безопасности, и всем пользователям рекомендуется обновиться до этих версий.
🔎 Неделя Symfony #950 (10–16 марта 2025 года)
На этой неделе в предстоящей версии Symfony 7.3 обновлены ленивые сервисы для использования нативных ленивых объектов PHP и добавлена возможность определения глобальных параметров перевода. В существующих версиях Symfony исправлена поддержка хуков PHP 8.4 и асимметричной видимости в
VarExporter
.Почему php -r «echo (int) ((0.1+0.7)*10);» выводит 7, а не 8?
В PHP выражение php -r «echo (int) ((0.1 + 0.7) * 10);» выводит 7 вместо ожидаемого 8 из-за особенностей представления чисел с плавающей точкой в компьютерах. Числа, такие как 0.1 и 0.7, не могут быть точно представлены в двоичной системе, что приводит к небольшим погрешностям при вычислениях. В данном случае, результат выражения (0.1 + 0.7) * 10 может быть немного меньше 8, например, 7.999999999999999, и при приведении к целому типу ((int)) дробная часть отбрасывается, давая результат 7.
Рекомендуемые подходы для получения ожидаемого результата:
Округление перед приведением к целому числу:
Используйте функцию round() для округления значения до ближайшего целого перед приведением к типу int:
Форматирование с заданной точностью:
Примените функцию sprintf() для форматирования числа с определённой точностью перед приведением:
Использование математических функций произвольной точности:
Для повышения точности вычислений можно использовать функции из расширения bcmath:
В PHP выражение php -r «echo (int) ((0.1 + 0.7) * 10);» выводит 7 вместо ожидаемого 8 из-за особенностей представления чисел с плавающей точкой в компьютерах. Числа, такие как 0.1 и 0.7, не могут быть точно представлены в двоичной системе, что приводит к небольшим погрешностям при вычислениях. В данном случае, результат выражения (0.1 + 0.7) * 10 может быть немного меньше 8, например, 7.999999999999999, и при приведении к целому типу ((int)) дробная часть отбрасывается, давая результат 7.
Рекомендуемые подходы для получения ожидаемого результата:
Округление перед приведением к целому числу:
Используйте функцию round() для округления значения до ближайшего целого перед приведением к типу int:
echo (int) round((0.1 + 0.7) * 10); // выводит 8
Форматирование с заданной точностью:
Примените функцию sprintf() для форматирования числа с определённой точностью перед приведением:
echo (int) sprintf('%.0f', (0.1 + 0.7) * 10); // выводит 8
Использование математических функций произвольной точности:
Для повышения точности вычислений можно использовать функции из расширения bcmath:
echo bcmul(bcadd('0.1', '0.7', 1), '10', 0); // выводит 8
#хочу_спросить
Задавайте любые вопросы о программировании и получайте ответы от пользователей. В комментариях под постом укажите #язык, #стек и/или #библиотеку, по которым задаете вопрос.
Задавайте любые вопросы о программировании и получайте ответы от пользователей. В комментариях под постом укажите #язык, #стек и/или #библиотеку, по которым задаете вопрос.
💻 Внедряем формулы как в Эксель
Пользователи постоянно меняют логику подсчёта? Они не довольны скоростью с которой вы меняете код? Уже надоело так часто менять одно и тоже? Если да, то получайте решение: пускай пользователи сами пишут формулы на языке, который им более знаком: это формулы эксель. От вас потребуется лишь надо научить своё приложение считать это. Как это сделать? С помощью чёрной магии конечно!
🔗 Хабр
Пользователи постоянно меняют логику подсчёта? Они не довольны скоростью с которой вы меняете код? Уже надоело так часто менять одно и тоже? Если да, то получайте решение: пускай пользователи сами пишут формулы на языке, который им более знаком: это формулы эксель. От вас потребуется лишь надо научить своё приложение считать это. Как это сделать? С помощью чёрной магии конечно!
🔗 Хабр
✅ Проверка того, является ли пользователь гостем в Laravel
Нам часто нужно проверить, прошел ли пользователь аутентификацию, и для этого мы используем метод «
Библиотека пхпшника #буст
Нам часто нужно проверить, прошел ли пользователь аутентификацию, и для этого мы используем метод «
check
». Но знаете ли вы, что когда вам нужно проверить, является ли пользователь гостем, вы можете использовать метод «guest
»? 🚀Библиотека пхпшника #буст
🧩 Чистое проектирование контроллеров в Symfony с помощью разрешителей аргументов
Статья рассказывает о механизме разрешения аргументов (argument resolving) в Symfony — процессе, который позволяет автоматически преобразовывать параметры запроса в объекты.
Ранее, до Symfony 6.2, для этого использовался SensioFrameworkExtraBundle с аннотацией
Symfony содержит несколько встроенных резолверов, которые помогают обрабатывать разные типы данных — от объектов запросов (RequestValueResolver) и пользовательских сессий (SessionValueResolver) до работы с датами (DateTimeValueResolver) и UID (UidValueResolver).
Создание кастомного аргумент-резолвера
Иногда стандартных резолверов недостаточно, например, если нужно загружать разные типы сущностей из одного маршрута. В статье рассматривается реальный пример с платформы Respawwwn, где есть разные игровые сессии (Daily, Survival, Collection, Party), но требуется один эндпоинт
Чтобы реализовать это, автор создаёт кастомный резолвер (GameSessionValueResolver), который:
✔️ Проверяет, является ли параметр id сущностью типа GameSessionInterface.
✔️ Ищет соответствующую игровую сессию в нескольких репозиториях.
✔️ Возвращает найденный объект, который затем передаётся в контроллер.
✔️ В контроллере этот резолвер подключается с помощью атрибута
Преимущества использования аргумент-резолверов
🔸 Чистый код — контроллеры не загромождены логикой преобразования параметров.
🔸 Гибкость — можно легко менять способ обработки параметров, не изменяя контроллеры.
🔸 Повторное использование — один резолвер можно применять в разных местах.
🔸 Тестируемость — можно отдельно протестировать резолвер без необходимости выполнять HTTP-запросы.
👉 Medium
Статья рассказывает о механизме разрешения аргументов (argument resolving) в Symfony — процессе, который позволяет автоматически преобразовывать параметры запроса в объекты.
Ранее, до Symfony 6.2, для этого использовался SensioFrameworkExtraBundle с аннотацией
@ParamConverter
, но теперь эту функцию выполняет встроенный EntityValueResolver. Это позволяет Symfony автоматически превращать идентификатор из URL (например, /messages/{id}
) в объект соответствующей сущности (например, Message).Symfony содержит несколько встроенных резолверов, которые помогают обрабатывать разные типы данных — от объектов запросов (RequestValueResolver) и пользовательских сессий (SessionValueResolver) до работы с датами (DateTimeValueResolver) и UID (UidValueResolver).
Создание кастомного аргумент-резолвера
Иногда стандартных резолверов недостаточно, например, если нужно загружать разные типы сущностей из одного маршрута. В статье рассматривается реальный пример с платформы Respawwwn, где есть разные игровые сессии (Daily, Survival, Collection, Party), но требуется один эндпоинт
/api/game-sessions/{id}/complete
, который может обработать любую из них.Чтобы реализовать это, автор создаёт кастомный резолвер (GameSessionValueResolver), который:
✔️ Проверяет, является ли параметр id сущностью типа GameSessionInterface.
✔️ Ищет соответствующую игровую сессию в нескольких репозиториях.
✔️ Возвращает найденный объект, который затем передаётся в контроллер.
✔️ В контроллере этот резолвер подключается с помощью атрибута
#[ValueResolver('game_session')]
, что делает код чище и удобнее.Преимущества использования аргумент-резолверов
🔸 Чистый код — контроллеры не загромождены логикой преобразования параметров.
🔸 Гибкость — можно легко менять способ обработки параметров, не изменяя контроллеры.
🔸 Повторное использование — один резолвер можно применять в разных местах.
🔸 Тестируемость — можно отдельно протестировать резолвер без необходимости выполнять HTTP-запросы.
👉 Medium
Prism
Унифицированный интерфейс для работы с LLM в Laravel. Поддерживает API Anthropic, DeepSeek, Gemini, Groq, Mistral, Ollama, OpenAI и xAI.
🔗 Github
#инструменты
Унифицированный интерфейс для работы с LLM в Laravel. Поддерживает API Anthropic, DeepSeek, Gemini, Groq, Mistral, Ollama, OpenAI и xAI.
🔗 Github
#инструменты
Установка Laravel 12 с помощью Docker за 8 минут — полное руководство по установке и настройке
Спидран по установке Laravel в докер, после чего сразу можно начать разработку или тестирование кода
👉 Видео
Библиотека пхпшника #буст
Спидран по установке Laravel в докер, после чего сразу можно начать разработку или тестирование кода
👉 Видео
Библиотека пхпшника #буст
YouTube
Install Laravel 12 with Docker in 8 Minutes - Full Setup & Configuration Guide #laravel #docker
Source code link: https://www.getmakedigital.com/blogs/laravel-12-development/install-laravel-12-with-docker
In this video, I'll show you how to install Laravel 12 with Docker in just 8 minutes. Whether you're a beginner or have some experience with Docker…
In this video, I'll show you how to install Laravel 12 with Docker in just 8 minutes. Whether you're a beginner or have some experience with Docker…
💻 Переворачиваем биты 32-битного числа в PHP
Bitwise-операции 🔢— это основа низкоуровневого программирования, криптографии и дебага. Одна из распространённых задач — инверсия битов 32-битного беззнакового числа: заменяем все 0 на 1 и наоборот.
📌 Что такое 32-битное беззнаковое число?
Оно хранит значения от
🔹 Как инвертировать биты в PHP?
PHP поддерживает побитовые операции с операторами ~ (NOT) и ^ (XOR).
❌
✅
🔍 Примеры работы кода
✅ Вход: 0
🔹 Бинарный вид: 00000000000000000000000000000000
🔹 Инверсия: 11111111111111111111111111111111
🔹 Десятичный результат: 4294967295
✅ Вход: 2147483647
🔹 Бинарный вид: 01111111111111111111111111111111
🔹 Инверсия: 10000000000000000000000000000000
🔹 Десятичный результат: 2147483648
Библиотека пхпшника #буст
Bitwise-операции 🔢— это основа низкоуровневого программирования, криптографии и дебага. Одна из распространённых задач — инверсия битов 32-битного беззнакового числа: заменяем все 0 на 1 и наоборот.
📌 Что такое 32-битное беззнаковое число?
Оно хранит значения от
0
до 4294967295
(2³² — 1
). В отличие от знаковых чисел, здесь нет отрицательных значений.🔹 Как инвертировать биты в PHP?
PHP поддерживает побитовые операции с операторами ~ (NOT) и ^ (XOR).
❌
~
меняет все биты, но из-за особенностей PHP приводит к отрицательным значениям.✅
^
(XOR) с 0xFFFFFFFF даёт правильный результат.🔍 Примеры работы кода
✅ Вход: 0
🔹 Бинарный вид: 00000000000000000000000000000000
🔹 Инверсия: 11111111111111111111111111111111
🔹 Десятичный результат: 4294967295
✅ Вход: 2147483647
🔹 Бинарный вид: 01111111111111111111111111111111
🔹 Инверсия: 10000000000000000000000000000000
🔹 Десятичный результат: 2147483648
Библиотека пхпшника #буст
Что умеет Rector: пишем кастомные правила для автоматизации рефакторинга PHP-проектов
Если вам часто приходится сталкиваться с рефакторингом старых PHP-проектов, при этом их потребности выходят за пределы штатного набора правил, эта статья для вас.
🔗 Хабр
Библиотека пхпшника
Если вам часто приходится сталкиваться с рефакторингом старых PHP-проектов, при этом их потребности выходят за пределы штатного набора правил, эта статья для вас.
🔗 Хабр
Библиотека пхпшника
📊 Тестовые задания — любовь или боль?
По данным исследования, 81% IT-специалистов в России просто игнорируют вакансии с тестовыми заданиями. Программисты оказались самыми «неприступными» — только 19% согласны их выполнять.
😆 Только тестировщики, которые сами по долгу службы гоняют тесты, готовы пройти их ради работы (63%). Профессиональная эмпатия?
Как вы относитесь к тестовым заданиям при трудоустройстве? Делитесь мнением в комментах! 👇
🔥 — готов(-а) выполнить, если вакансия интересная
👍 — только если тестовое оплачивается
🌚 — игнорю такие вакансии сразу
🤔 — я уже делал(-а) тестовое, а его использовали в проде бесплатно
Библиотека пхпшника #междусобойчик
По данным исследования, 81% IT-специалистов в России просто игнорируют вакансии с тестовыми заданиями. Программисты оказались самыми «неприступными» — только 19% согласны их выполнять.
😆 Только тестировщики, которые сами по долгу службы гоняют тесты, готовы пройти их ради работы (63%). Профессиональная эмпатия?
Как вы относитесь к тестовым заданиям при трудоустройстве? Делитесь мнением в комментах! 👇
🔥 — готов(-а) выполнить, если вакансия интересная
👍 — только если тестовое оплачивается
🌚 — игнорю такие вакансии сразу
🤔 — я уже делал(-а) тестовое, а его использовали в проде бесплатно
Библиотека пхпшника #междусобойчик
💻 Подборка новостей по PHP за неделю:
🔎 Релиз CakePHP 4.5.10
Команда CakePHP объявила о выходе версии 4.5.10. Это технический релиз, исправляющий несколько проблем, о которых сообщило сообщество.
GitHub
🔎 Расширение JetBrains Xdebug Helper для браузера
JetBrains представила официальное расширение Xdebug Helper для Chrome, обеспечивающее беспроблемную отладку PHP-кода.
🔎 Laravel 12.3: Новый тип приведения JSON Unicode
Команда Laravel выпустила версию 12.3.0, включающую новый тип приведения JSON Unicode, проверку статуса связанных хранилищ в команде about, поддержку нативных типов JSON и JSONB в схемах SQLite и другие улучшения.
🔎 Неделя Symfony #951 (17–23 марта 2025 года)
На этой неделе в предстоящей версии Symfony 7.3 обновлена конфигурация по умолчанию для исключения расширений контейнера, сущностей и сообщений Messenger при регистрации сервисов, а также внесены изменения, связанные с сбросом сервисов.
Библиотека пхпшника #свежак
🔎 Релиз CakePHP 4.5.10
Команда CakePHP объявила о выходе версии 4.5.10. Это технический релиз, исправляющий несколько проблем, о которых сообщило сообщество.
GitHub
🔎 Расширение JetBrains Xdebug Helper для браузера
JetBrains представила официальное расширение Xdebug Helper для Chrome, обеспечивающее беспроблемную отладку PHP-кода.
🔎 Laravel 12.3: Новый тип приведения JSON Unicode
Команда Laravel выпустила версию 12.3.0, включающую новый тип приведения JSON Unicode, проверку статуса связанных хранилищ в команде about, поддержку нативных типов JSON и JSONB в схемах SQLite и другие улучшения.
🔎 Неделя Symfony #951 (17–23 марта 2025 года)
На этой неделе в предстоящей версии Symfony 7.3 обновлена конфигурация по умолчанию для исключения расширений контейнера, сущностей и сообщений Messenger при регистрации сервисов, а также внесены изменения, связанные с сбросом сервисов.
Библиотека пхпшника #свежак