Библиотека собеса по PHP | вопросы с собеседований
3.38K subscribers
138 photos
2 videos
68 links
Вопросы с собеседований по PHP и ответы на них.

По рекламе: @proglib_adv

Учиться у нас: https://proglib.io/w/9f3affba

Работать у нас: https://job.proglib.io/

Наши каналы: https://yangx.top/proglibrary/9197
加入频道
В чем разница между криптографическими функциями md5(), crc32() и sha1() в PHP?

В PHP md5(), crc32() и sha1() — это все криптографические хеш-функции, но они имеют различия в размере вывода, стойкости к коллизиям и алгоритмах.

md5():

md5() создает хеш-значение размером 128 бит (16 байт).
Широко используется для контрольных сумм и криптографических хеш-функций.
Однако из-за обнаруженных уязвимостей, его больше не рекомендуется использовать для криптографических целей, где требуется надежная защита от коллизий.

crc32():

crc32() генерирует 32-битное (4 байта) контрольное значение циклической избыточности (CRC).
Обычно используется для проверки ошибок в передаче данных.
Не подходит для криптографических целей из-за отсутствия криптографической надежности и высокой вероятности коллизий, особенно для коротких входных данных.

sha1():

sha1() создает хеш-значение размером 160 бит (20 байт).
Более безопасен, чем md5() и crc32(), но также подвержен атакам на коллизии.
В некоторых приложениях все еще используется, но обычно считается менее безопасным, чем более современные алгоритмы хеширования, такие как SHA-256 или SHA-512.
Для чего используется переменная $_REQUEST?

Переменная $_REQUEST является суперглобальным массивом, который используется для сбора данных из HTML-форм или URL-адресов. Это комбинация массивов $_GET, $_POST и $_COOKIE. Собранные данные могут быть параметрами, переданными через методы HTTP GET или POST.

Вот разбор того, что представляет собой каждый из этих методов:

$_GET: Данные, отправленные через строку запроса URL. Они видны всем и имеют ограничение на объем передаваемых данных.

$_POST: Данные, отправленные через HTTP POST-запрос, обычно из HTML-формы с использованием метода POST. Эти данные не видны в URL-адресе и могут передавать больший объем данных по сравнению с $_GET.

$_COOKIE: Данные, хранящиеся в файлах cookie браузера пользователя.

$_REQUEST позволяет получать доступ к данным независимо от того, как они были отправлены, будь то запрос GET (параметры URL), запрос POST (отправка формы) или cookie. Однако полагаться исключительно на $_REQUEST иногда может привести к проблемам с безопасностью, поскольку он объединяет различные источники пользовательского ввода. Обычно рекомендуется использовать явно $_GET, $_POST или $_COOKIE в зависимости от предполагаемого использования и источника данных, поскольку это обеспечивает большую ясность и безопасность.
Есть ли разница между self и this в PHP?

В PHP ключевое слово self и ключевое слово this в общем контексте имеют разные значения и применяются в разных контекстах.

self: Это ключевое слово используется внутри классов для обращения к статическим свойствам и методам класса, а также для вызова статических методов класса внутри других методов этого же класса. Ключевое слово self ссылается на текущий класс.

this: Это ключевое слово также используется внутри классов, но оно относится к текущему объекту этого класса. this ссылается на конкретный экземпляр класса, через который вызывается метод или обращение к свойствам.

Таким образом, основное различие между self и this в PHP заключается в том, что self используется для работы со статическими свойствами и методами класса, а this используется для работы с нестатическими (экземплярными) свойствами и методами класса.
Как реализовать шаблон проектирования «Наблюдатель» на PHP, и какие типичные сценарии использования для него существуют?

Шаблон проектирования «Наблюдатель» используется, когда существует зависимость «один ко многим» между объектами, так что при изменении состояния одного объекта все зависимые объекты автоматически уведомляются и обновляются. На PHP этот паттерн можно реализовать, используя интерфейсы и классы.

Типичные сценарии использования для паттерна «Наблюдатель» включают:

Системы обработки событий: Когда происходит событие, такое как клик кнопки или изменение данных, все зарегистрированные наблюдатели (слушатели событий) уведомляются.

Архитектуры MVC: Наблюдатели (представления) подписываются на изменения в модели, автоматически обновляя себя при изменении состояния модели.

Распределенные системы: Компоненты распределенной системы могут нуждаться в уведомлении о изменениях в других компонентах, и паттерн «Наблюдатель» может облегчить эту коммуникацию.

Системы ведения логов и мониторинга: Наблюдатели могут использоваться для отслеживания изменений в состоянии системы и регистрации соответствующей информации.

Контейнеры внедрения зависимостей: Наблюдатели могут использоваться для уведомления зависимых объектов о изменениях в конфигурации или состоянии контейнера.
Как работает HTTP Kernel в Symfony?

HTTP Kernel (HTTP ядро) в Symfony — это ключевой компонент фреймворка, отвечающий за обработку HTTP-запросов и формирование ответов. Он реализует шаблон проектирования Front Controller и координирует весь жизненный цикл запроса и ответа.

Основной процесс работы HTTP Kernel

1. Получение запроса:
Входной файл (index.php) получает HTTP-запрос и передаёт его в ядро.

2. Маршрутизация:
Ядро использует компонент маршрутизации, чтобы определить, какой маршрут соответствует запросу, и какой контроллер должен быть вызван.

3. Вызов контроллера:
После определения маршрута вызывается соответствующий контроллер, который обрабатывает запрос и возвращает данные.

4. Формирование ответа:
Контроллер возвращает объект ответа, который может быть модифицирован дополнительными обработчиками (например, добавление заголовков).

5. Отправка ответа:
HTTP ядро отправляет готовый ответ обратно клиенту.

6. Постобработка:
После отправки ответа запускаются задачи, которые можно выполнять асинхронно (например, логирование или очистка данных).

Основные компоненты
🔹 Запрос и ответ:
Symfony использует объект запроса, который содержит все данные HTTP-запроса (заголовки, параметры, тело и т.д.), и объект ответа, который формирует конечный HTTP-ответ.

🔹 Маршрутизация:
Компонент маршрутизации сопоставляет URL запроса с маршрутами, указанными в конфигурации, и определяет, какой контроллер и параметры использовать.

🔹 Контроллер:
Контроллер — это метод, который выполняет бизнес-логику, принимает параметры из запроса и возвращает ответ.

🔹 События:
Во время обработки запроса ядро генерирует события, на которые могут подписываться обработчики. Это позволяет изменять запрос, контроллер или ответ на разных этапах обработки.

🔹 Постобработка:
После того как ответ отправлен клиенту, могут выполняться задачи, которые не требуют немедленного завершения (например, отправка логов или очистка кэша).

Этапы обработки запроса
✔️Клиент отправляет HTTP-запрос.
✔️Ядро принимает запрос и вызывает маршрутизацию.
✔️Контроллер выполняет бизнес-логику.
✔️Генерируется HTTP-ответ.
✔️Ответ модифицируется при необходимости (например, добавляются заголовки).
✔️Готовый ответ отправляется клиенту.
✔️Выполняются завершающие задачи.
💻 Эффективное проектирование программных систем

Правильная архитектура программного обеспечения помогает создавать устойчивые и масштабируемые приложения, которые легко дорабатывать и поддерживать.

Наш интенсив «Архитектуры и шаблоны проектирования» научит вас строить программные системы без боли и стресса. Вы на практике освоите основные паттерны проектирования и прокачайте свои навыки архитектора программного обеспечения.

🎄Начните свой 2025 со скидкой 35% на все курсы. Это лучшее вложении уходящего года – https://proglib.io/w/cc21e069
Какова цель ключевого слова «use» в пространствах имен PHP?

Псевдонимы пространств имен или классов: Позволяет задать более короткие и удобные имена для длинных пространств имен или классов. Это делает код более читаемым и кратким.

Импорт констант: Позволяет импортировать константы, определенные в пространстве имен, с помощью use:

Импорт функций (начиная с PHP 8): В PHP 8 и выше вы также можете импортировать функции из пространства имен в текущее пространство имен, используя use function.

Импорт констант (начиная с PHP 8): Аналогично, в PHP 8 и выше вы можете импортировать константы из пространства имен в текущее пространство имен с помощью use const.

Используя use, вы можете сделать свой код более чистым и поддерживаемым, уменьшая необходимость повторного использования полностью квалифицированных имен в вашем коде.
Что такое cursor в MySQL-процедурах?

В MySQL курсор (cursor) — это инструмент, используемый внутри хранимых процедур и триггеров для обработки и управления результатами запросов, возвращающих множество строк (т. е. многими результатами). Курсор позволяет пошагово проходить по каждой строке результата запроса, чтобы выполнять операции на уровне каждой строки.

Основные характеристики курсоров:
Управление строками по одной:
Курсор позволяет работать с каждой строкой из набора результатов, возвращаемого запросом.

Используется в хранимых процедурах: Курсоры чаще всего применяются внутри хранимых процедур, где требуется выполнить сложную логику обработки данных.

Временный объект: Курсор существует только в рамках выполнения процедуры и уничтожается по завершении процедуры.

Основные этапы работы с курсорами:
1. Объявление курсора: Определяется запрос, который будет использовать курсор.

DECLARE cursor_name CURSOR FOR
SELECT column1, column2 FROM table_name WHERE condition;

2. Открытие курсора: Подготавливает курсор для работы.

OPEN cursor_name;


3. Чтение данных из курсора (извлечение строки): Используется команда FETCH, чтобы извлечь текущую строку из курсора.

FETCH cursor_name INTO var1, var2;

4. Закрытие курсора: После завершения работы курсор должен быть закрыт.

CLOSE cursor_name;

Важные моменты:
Обработчик ошибок: Используется для обработки ситуации, когда курсор достиг конца набора данных (NOT FOUND).
Эффективность: Курсоры могут быть менее производительными, чем операции над наборами данных, поэтому их следует использовать только при необходимости построчной обработки.
Ограничения: В MySQL курсоры не поддерживают параллельное выполнение и обычно работают медленнее, чем аналогичные механизмы в других СУБД.

Курсоры полезны для задач, требующих пошаговой обработки данных, но по возможности их лучше избегать, используя SQL-запросы, оптимизированные для работы с наборами данных.
В чем различие между шаблонами проектирования «Фабрика» и «Абстрактная фабрика»?

Паттерн «Фабрика»:

Паттерн «Фабрика» — это порождающий паттерн проектирования, который предоставляет интерфейс для создания объектов без указания их конкретных классов.
Он инкапсулирует логику создания объектов, позволяя подклассам или производным классам изменять тип создаваемых объектов.
В PHP паттерн «Фабрика» обычно включает в себя класс с методом (часто называемым create или подобным), ответственным за создание и возвращение объектов различных типов на основе определенных условий или параметров.

Паттерн «Абстрактная фабрика»:


Паттерн «Абстрактная фабрика» также является порождающим паттерном проектирования, но он сосредоточен на предоставлении интерфейса для создания семейств связанных или зависимых объектов без указания их конкретных классов.
Он определяет абстрактный класс (или интерфейс), который объявляет методы для создания абстрактных объектов-продуктов. Затем подклассы реализуют эти методы для создания конкретных объектов-продуктов, принадлежащих к определенному семейству.
В PHP паттерн «Абстрактная фабрика» обычно включает несколько связанных фабричных классов (конкретных фабрик), каждый из которых ответственен за создание семейств связанных объектов (продуктов).
🎨 Новый канал для вдохновения — UX in GIF

Мы запустили свежий канал, где делимся идеями для дизайна интерфейсов. Всё самое стильное, оригинальное и вдохновляющее теперь в одном месте.

📌 Чем полезен канал?

→ Идеи для дизайна интерфейсов.
→ Анимации, которые можно повторить или адаптировать.
→ Лёгкий способ искать вдохновение перед новым проектом.

👉 Подписывайтесь и вдохновляйтесь: UX in GIF
Please open Telegram to view this post
VIEW IN TELEGRAM
Что такое ссылки?

В контексте собеседования можно ответить по разному, учитывая какие ссылки имеются в виду:

1️⃣Ссылки в PHP:
В PHP ссылки (references) — это специальный тип переменных, который позволяет создавать два (или более) разных имени для одной и той же переменной. Использование ссылок в PHP может быть полезным для передачи аргументов функции по ссылке, что позволяет изменять исходные значения переменных внутри функции.

2️⃣Ссылки на объекты:
В PHP также можно использовать ссылки на объекты. При работе с объектами, ссылки могут использоваться для создания нескольких имён, ссылающихся на один и тот же экземпляр объекта.
Всех с наступившим новым годом!❤️🌲

С завтрашнего дня посты выходят в прежнем режиме.
Какие основные операции с использованием ссылок?

✔️Присвоение переменной ссылки на другую переменную

✔️Передача аргументов функции по ссылке

✔️Возвращение значения по ссылке из функции

✔️Создание ссылки на элемент массива

✔️Ссылки на объекты

Это основные операции, которые можно выполнить с использованием ссылок в PHP. Они часто используются для оптимизации работы с памятью и передачи значений между переменными и функциями. Однако следует быть осторожным с использованием ссылок, чтобы избежать нежелательных побочных эффектов и ошибок в коде.
Что такое OWASP?

OWASP — это акроним, расшифровывающийся как Open Web Application Security Project.

OWASP — это некоммерческая организация, которая занимается исследованием и обеспечением безопасности веб-приложений. Она обладает обширным контентом, включающим методологии, инструменты, стандарты и руководства по обеспечению безопасности веб-приложений.

В рамках OWASP разработаны множество проектов, включающих в себя руководства по безопасности, топ-10 уязвимостей веб-приложений, инструменты для сканирования и тестирования безопасности, образцы кода и многое другое.

Знание OWASP и умение применять его рекомендации является важным для php-разработчика, так как помогает защитить веб-приложения от распространенных уязвимостей, таких как инъекции SQL, межсайтовый скриптинг (XSS), утечка конфиденциальной информации и другие.
Расскажите про MVC

Реализация архитектуры Model-View-Controller (MVC) в приложении на PHP включает организацию кода в три основных компонента: Модель (Model), Представление (View) и Контроллер (Controller). Каждый компонент имеет свои собственные обязанности, что помогает разделить задачи и сделать код более поддерживаемым и масштабируемым.

Вот краткий обзор каждого компонента и способов их реализации в приложении на PHP:

Модель (Model): Модель представляет данные и бизнес-логику приложения. Она взаимодействует с базой данных или любым другим источником данных, выполняет валидацию данных и реализует бизнес-правила. В PHP вы можете создавать классы для ваших моделей, которые инкапсулируют операции доступа и манипулирования данными. Например, у вас может быть класс модели User, который обрабатывает операции, связанные с пользователями, такие как получение данных пользователя, обновление информации о пользователе и т. д.

Представление (View): Представление отвечает за отображение данных пользователю. Оно генерирует HTML-вывод, который пользователь видит в своем браузере. В PHP представления обычно реализуются как отдельные шаблонные файлы, содержащие HTML вместе с заполнителями для динамического контента. Вы можете использовать операторы include или require PHP для включения этих шаблонов в ваши действия контроллера.

Контроллер (Controller): Контроллер действует как посредник между моделью и представлением. Он получает ввод пользователя, взаимодействует с моделью для извлечения или обновления данных, а затем передает эти данные представлению для отображения. В PHP контроллеры обычно реализуются как классы с методами, соответствующими различным действиям или маршрутам в приложении. Эти методы обрабатывают запросы пользователя, извлекают данные из модели и передают их представлению.

Преимущества использования архитектуры MVC в PHP-приложениях включают в себя:

Разделение забот (Separation of Concerns): MVC разделяет логику представления (view) от бизнес-логики (model) и обработки ввода пользователя (controller), что делает кодовую базу более понятной, поддерживаемой и обновляемой.

Модульность и повторное использование кода (Modularity and Reusability): Компоненты в MVC слабо связаны, что позволяет легче повторно использовать и модифицировать код. Например, вы можете повторно использовать тот же класс модели в разных контроллерах или представлениях.

Масштабируемость (Scalability): MVC способствует структурированному подходу к разработке, что упрощает масштабирование вашего приложения по мере его роста в сложности. Новые функции могут быть добавлены без влияния на существующий код, а изменения могут быть внесены более эффективно.

Тестирование (Testability): Поскольку каждый компонент в MVC имеет свои собственные обязанности, легче писать модульные тесты для отдельных компонентов, что приводит к более надежному коду.

Улучшение совместной работы (Improved Collaboration): MVC способствует четкому разделению забот, что упрощает совместную работу разработчиков над различными частями приложения, не мешая друг другу.
Расскажите об автоматических анализаторах кода PHP (roundcube т.д.).

Автоматические анализаторы кода PHP — это инструменты, которые помогают разработчикам исследовать, оценивать и улучшать качество своего PHP-кода. Они предлагают различные функции, такие как статический анализ кода, поиск потенциальных проблем, обнаружение ошибок, а также рекомендации по улучшению читаемости и производительности кода. Они могут быть полезны как для индивидуальных разработчиков, так и для командных проектов, чтобы обеспечить согласованность и высокое качество кода.

Один из популярных автоматических анализаторов кода для PHP — это PHP_CodeSniffer. Он предоставляет возможности статического анализа, проверки соответствия кода стандартам оформления (например, PSR-1, PSR-2) и поиска потенциальных проблемных мест. PHP_CodeSniffer позволяет создавать собственные наборы правил и настраивать их под конкретные потребности проекта.

Еще одним популярным инструментом является PHPStan. Он предоставляет статический анализ кода на основе аннотаций типов, что позволяет обнаруживать потенциальные ошибки и проблемы на этапе разработки. PHPStan также может помочь в улучшении производительности и читаемости кода.

Для проектов с открытым исходным кодом, таких как Roundcube (веб-почтовый клиент), часто используются автоматические анализаторы кода для поддержания высокого качества кодовой базы и улучшения безопасности. Эти инструменты помогают разработчикам быстро находить и исправлять проблемы, уменьшая риск возникновения ошибок и улучшая общее качество программного обеспечения.
Расскажите о SSH-протоколе

SSH (Secure Shell) — это протокол сетевой службы, который используется для безопасной передачи данных через незащищенную сеть. Он обеспечивает шифрование данных, аутентификацию и защиту от атак типа «прослушивание» (sniffing) и подмены данных (spoofing).

В контексте PHP SSH-протокол может использоваться для удаленного выполнения команд на сервере. Это особенно полезно, если вы хотите автоматизировать какие-то процессы на удаленном сервере из своего веб-приложения, например, управление файлами, обновление программного обеспечения или настройка сервера.

Cуществует несколько способов взаимодействия с SSH:

PHP расширение SSH2: PHP SSH2 extension предоставляет интерфейс для работы с SSH. Оно позволяет устанавливать SSH-соединения, выполнение команд, передачу файлов и другие операции. Для использования этого расширения необходимо установить его на сервере.

Библиотеки PHP для SSH: Существуют сторонние библиотеки PHP, такие как phpseclib, которые предоставляют альтернативные способы работы с SSH без необходимости установки дополнительных расширений PHP. Phpseclib, например, предоставляет классы для работы с SSH, SFTP и другими криптографическими протоколами.

Использование внешних инструментов: Вы также можете использовать внешние инструменты, такие как OpenSSH, с помощью функций PHP для выполнения команд на сервере. Например, функция exec() или shell_exec() позволяют выполнить команду на сервере, включая команды SSH.

Важно помнить о безопасности при работе с SSH в PHP. Необходимо обеспечить безопасное хранение учетных данных для доступа к серверу (лучше всего использовать ключи SSH вместо паролей) и обеспечить проверку вводимых данных для предотвращения атак вроде внедрения кода (code injection). Кроме того, следует ограничить возможности выполнения команд на сервере, чтобы избежать потенциальных угроз безопасности.