Библиотека собеса по PHP | вопросы с собеседований
3.18K subscribers
177 photos
5 videos
118 links
Вопросы с собеседований по PHP и ответы на них.

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

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

Для обратной связи: @proglibrary_feeedback_bot
Download Telegram
⚡️ Механизм запущен, часики тикают

Прямо сейчас кто-то уже купил курс со скидкой 40%, открыл первый урок и уже на пути к MacBook Pro 14.

А ты всё ещё читаешь этот пост...

Дедлайны не ждут:

31 октября — скидка 40% сгорает
15 ноября — розыгрыш MacBook

🎯 Правила участия:

→ купить любой курс до 31 октября
→ отучиться 2 недели
→ написать #розыгрыш куратору

🕊️ Не упусти свой шанс
Расскажите о 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). Кроме того, следует ограничить возможности выполнения команд на сервере, чтобы избежать потенциальных угроз безопасности.
Какие есть типы индексов в бд?

Использование индексов в базах данных подразумевает их создание, просмотр и удаление для оптимизации запросов. Индексы ускоряют операции чтения (SELECT), но могут замедлить операции записи (INSERT, UPDATE, DELETE).

Общий синтаксис создания индекса выглядит следующим образом:

CREATE INDEX имя_индексаON имя_таблицы (столбец1 [ASC|DESC], столбец2 [ASC|DESC]);


Вот основные типы индексов:

1. Кластерные индексы (Clustered Index)
🔸 Упорядочивают данные в таблице в соответствии с индексом.
🔸 Каждая таблица может иметь только один кластерный индекс, так как физический порядок строк определяется им.
🔸 Пример: Первичный ключ часто создается как кластерный индекс.

Преимущества:

🔹 Быстрый доступ к данным в диапазонных запросах.
🔹 Эффективно при выборке упорядоченных данных.

Недостатки:

🔹 Медленные операции вставки, обновления и удаления, так как данные переносятся для сохранения порядка.

2. Некластерные индексы (Non-Clustered Index)
🔸 Содержат указатели на фактические строки данных.
🔸 Таблица может иметь несколько некластерных индексов.
🔸 Пример: Индексация столбца, который часто используется в условиях WHERE.

Преимущества:

🔹 Быстрый доступ к конкретным значениям.
🔹 Может использоваться для оптимизации запросов с различными столбцами.

Недостатки:

🔹 Дополнительное использование дискового пространства.
🔹 Замедление операций вставки, обновления и удаления.

3. Уникальные индексы (Unique Index)
🔸 Обеспечивают уникальность значений в одном или нескольких столбцах.
🔸 Пример: Индекс на email-адрес в таблице пользователей.

Преимущества:

🔹 Поддерживает целостность данных.
🔹 Повышает производительность запросов.

Недостатки:

🔹 Невозможно хранить дублирующиеся значения.

4. Составные индексы (Composite Index)
🔸 Создаются на основе нескольких столбцов.
🔸 Пример: Индекс на столбцы (lastname, firstname).

Преимущества:

🔹 Улучшает производительность запросов, где используются все или часть индекса.

Недостатки:

🔹 Требует внимательного проектирования, чтобы учитывать порядок столбцов.

5. Полнотекстовые индексы (Full-Text Index)
🔸 Используются для поиска текстовых данных, таких как документы или длинные текстовые поля.
🔸 Пример: Полнотекстовый поиск по колонке description в таблице товаров.

Преимущества:

🔹 Оптимизирован для поиска ключевых слов или фраз.

Недостатки:

🔹 Поддерживается не всеми СУБД.
🔹 Может занимать значительное место.

6. Битмап-индексы (Bitmap Index)
🔸 Представляют данные в виде битовых карт.
🔸 Чаще всего используются в столбцах с низкой кардинальностью (небольшим количеством уникальных значений).

Преимущества:

🔹 Эффективны для аналитических запросов и запросов с большими объемами данных.

Недостатки:

🔹 Не подходят для таблиц с частыми изменениями данных.

7. XML/JSON Индексы
🔸 Оптимизируют поиск в данных, хранящихся в XML или JSON-форматах.

Преимущества:

🔹 Ускоряют сложные запросы по вложенным структурам.

Недостатки:

🔹 Занимают дополнительное пространство.
🔹 Ограниченная поддержка в некоторых СУБД.

8. Пространственные индексы (Spatial Index)
🔸 Используются для работы с географическими и пространственными данными.
🔸 Пример: Индексация координат в базе данных геоинформационных систем.

Преимущества:

🔹 Эффективны для запросов, связанных с расстояниями, полигонами и геометрией.

9. Хэш-индексы (Hash Index)
🔸 Используют хэш-функции для индексирования данных.
🔸 Пример: Подходит для равенства (например, WHERE column = value).

Преимущества:

🔹 Очень быстрые запросы на точное совпадение.

Недостатки:

🔹 Не поддерживают диапазонные запросы.
Halloween Special — последний день магии! 👻

Успевай сегодня купить курсы со скидкой 40%!

А также участвуй в розыгрыше MacBook Pro 14 💻

После полуночи останется только тыква 🎃

🔮 Открой портал и выбери курс
Есть ли разница между одинарными и двойными кавычками?

Да, есть

Двойные кавычки: Внутри двойных кавычек PHP разбирает переменные и экранирует специальные символы, такие как новая строка (\n) или символы управления (например, \t для табуляции).

Одинарные кавычки: Внутри одинарных кавычек PHP не разбирает переменные и не экранирует специальные символы, кроме одиночного обратного слэша.

Поэтому, в тех случаях когда в вашей строке заведомо не используются специальные символы и переменные следует использовать именно одинарные, так как это повышает скорость выполнения, поскольку избавляет PHP от необходимости парсить строку
3😢1🥱1
Что означает одиночное наследование в PHP?

Одиночное наследование в PHP означает возможность класса наследовать свойства и методы только от одного родительского класса. Другими словами, дочерний класс может иметь только один прямой родительский класс, от которого он наследует. Это в отличие от множественного наследования, где класс может наследовать от нескольких родительских классов.

В PHP одиночное наследование применяется самим языком. Когда класс расширяет другой класс с использованием ключевого слова extends, устанавливается отношение родитель-потомок, и дочерний класс наследует все неприватные свойства и методы родительского класса.

В целом, можно сказать, что для компенсации отсутствия множественного наследования в PHP используются интерфейсы и трейты.
Какие HTTP-методы знаете?

Веб-протокол HTTP (Hypertext Transfer Protocol) определяет различные методы запросов, которые клиенты могут отправлять серверу для выполнения определенных операций. Некоторые из наиболее распространенных HTTP-методов:

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

POST: Отправить данные на сервер для обработки. Обычно используется для отправки данных формы или для выполнения какой-то операции на сервере, которая может изменить состояние сервера или добавить новые данные.

PUT: Заменить все текущие представления ресурса данными запроса. Используется для создания или обновления ресурса на сервере.

DELETE: Удалить указанный ресурс с сервера.

PATCH: Изменить часть ресурса на сервере. Используется для частичного обновления ресурса.

HEAD: Получить заголовки, которые будут отправлены при GET-запросе на указанный ресурс. Этот метод полезен, когда клиенту нужны только заголовки, а не фактическое содержимое.

OPTIONS: Получить информацию о возможностях сервера относительно ресурса или сервера в целом. Это может включать доступные методы, поддерживаемые заголовки и другую метаинформацию.

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

CONNECT: Используется для установки виртуального соединения с сервером, обеспечивая прозрачное шифрование SSL через промежуточный узел.
👍4
Как использовать компонент Symfony Console для создания пользовательской команды?

Чтобы создать пользовательскую команду в компоненте Symfony's Console, вам сначала нужно создать новый PHP-класс, который расширяет класс Command. Этот класс должен быть расположен в каталоге bundle. В этом классе настройте имя команды, аргументы и опции в методе configure(). Реализуйте логику команды в методе execute().

После создания команды зарегистрируйте ее как сервис, пометив console.command в файле конфигурации сервисов. Теперь вы можете запускать команду из консоли, используя ее имя, заданное в $defaultName.
📕Делаем тонкие контроллеры на Symfony. Валидация - PHP-разработчикам; Junior/Middle разработчикам, строящим API на Symfony; начинающим специалистам в асинхронной архитектуре

На открытом уроке 5 ноября в 20:00 мск мы разберёмся в принципах и методах разработки тонких контроллеров:

📗 На вебинаре:
1. Получите практические примеры построения эффективной архитектуры приложения.
2. Познакомитесь с базовыми механизмами валидации.

📘 В результате на практике изучите и освоите создание собственных constraint, а также сможете централизованно обрабатывать ошибки с помощью EventDispatcher/EventListener.

👉 Регистрация на урок и подробности о курсе Symfony Framework: https://otus.pw/gd2Ua/

Все участники открытого урока получат скидку на курс "Symfony Framework"

Реклама. ООО «Отус онлайн-образование», ОГРН 1177746618576
Как можно получить свойства изображения в PHP?

getimagesize() — используется для получения размера изображения.
exif_imagetype() — используется для получения типа изображения.
imagesx() — используется для получения ширины изображения.
imagesy() — используется для получения высоты изображения.
👍1
[Git]Какой командой можно влить комит в текущую ветку?

Чтобы влить коммит в текущую ветку, используется команда git cherry-pick. Эта команда позволяет перенести один или несколько коммитов из другой ветки или из истории на текущую ветку. Вот как это делается:

1. Определите хэш коммита, который вы хотите влить:

git log

Найдите нужный коммит и скопируйте его хэш.

2. Выполните команду cherry-pick:

git cherry-pick 


Если вам нужно влить несколько коммитов, вы можете указать диапазон:

git cherry-pick ^..


Или перечислить несколько хэшей:

git cherry-pick   


После выполнения cherry-pick, изменения из выбранных коммитов будут добавлены в вашу текущую ветку.

Дополнительные моменты:
Если возникнут конфликты при выполнении git cherry-pick, Git остановится и предложит вам их разрешить. После разрешения конфликтов выполните:
git cherry-pick --continue


Если вы передумали в процессе выполнения cherry-pick, вы можете отменить операцию с помощью:
git cherry-pick --abort
👍2