⚡️ Механизм запущен, часики тикают
Прямо сейчас кто-то уже купил курс со скидкой 40%, открыл первый урок и уже на пути к MacBook Pro 14.
А ты всё ещё читаешь этот пост...
⏰ Дедлайны не ждут:
31 октября — скидка 40% сгорает
15 ноября — розыгрыш MacBook
🎯 Правила участия:
→ купить любой курс до 31 октября
→ отучиться 2 недели
→ написать #розыгрыш куратору
🕊️ Не упусти свой шанс
Прямо сейчас кто-то уже купил курс со скидкой 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). Кроме того, следует ограничить возможности выполнения команд на сервере, чтобы избежать потенциальных угроз безопасности.
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).
Общий синтаксис создания индекса выглядит следующим образом:
Вот основные типы индексов:
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).
Преимущества:
🔹 Очень быстрые запросы на точное совпадение.
Недостатки:
🔹 Не поддерживают диапазонные запросы.
Использование индексов в базах данных подразумевает их создание, просмотр и удаление для оптимизации запросов. Индексы ускоряют операции чтения (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 💻
После полуночи останется только тыква 🎃
🔮 Открой портал и выбери курс
Успевай сегодня купить курсы со скидкой 40%!
А также участвуй в розыгрыше MacBook Pro 14 💻
После полуночи останется только тыква 🎃
🔮 Открой портал и выбери курс
Есть ли разница между одинарными и двойными кавычками?
Да, есть
Двойные кавычки: Внутри двойных кавычек PHP разбирает переменные и экранирует специальные символы, такие как новая строка (\n) или символы управления (например, \t для табуляции).
Одинарные кавычки: Внутри одинарных кавычек PHP не разбирает переменные и не экранирует специальные символы, кроме одиночного обратного слэша.
Поэтому, в тех случаях когда в вашей строке заведомо не используются специальные символы и переменные следует использовать именно одинарные, так как это повышает скорость выполнения, поскольку избавляет PHP от необходимости парсить строку
Да, есть
Двойные кавычки: Внутри двойных кавычек PHP разбирает переменные и экранирует специальные символы, такие как новая строка (\n) или символы управления (например, \t для табуляции).
Одинарные кавычки: Внутри одинарных кавычек PHP не разбирает переменные и не экранирует специальные символы, кроме одиночного обратного слэша.
Поэтому, в тех случаях когда в вашей строке заведомо не используются специальные символы и переменные следует использовать именно одинарные, так как это повышает скорость выполнения, поскольку избавляет PHP от необходимости парсить строку
❤3😢1🥱1
Что означает одиночное наследование в PHP?
Одиночное наследование в PHP означает возможность класса наследовать свойства и методы только от одного родительского класса. Другими словами, дочерний класс может иметь только один прямой родительский класс, от которого он наследует. Это в отличие от множественного наследования, где класс может наследовать от нескольких родительских классов.
В PHP одиночное наследование применяется самим языком. Когда класс расширяет другой класс с использованием ключевого слова
В целом, можно сказать, что для компенсации отсутствия множественного наследования в PHP используются интерфейсы и трейты.
Одиночное наследование в PHP означает возможность класса наследовать свойства и методы только от одного родительского класса. Другими словами, дочерний класс может иметь только один прямой родительский класс, от которого он наследует. Это в отличие от множественного наследования, где класс может наследовать от нескольких родительских классов.
В PHP одиночное наследование применяется самим языком. Когда класс расширяет другой класс с использованием ключевого слова
extends, устанавливается отношение родитель-потомок, и дочерний класс наследует все неприватные свойства и методы родительского класса.В целом, можно сказать, что для компенсации отсутствия множественного наследования в PHP используются интерфейсы и трейты.
Какие HTTP-методы знаете?
Веб-протокол HTTP (Hypertext Transfer Protocol) определяет различные методы запросов, которые клиенты могут отправлять серверу для выполнения определенных операций. Некоторые из наиболее распространенных HTTP-методов:
GET: Получить данные с сервера. Этот метод используется для запроса содержимого указанного ресурса.
POST: Отправить данные на сервер для обработки. Обычно используется для отправки данных формы или для выполнения какой-то операции на сервере, которая может изменить состояние сервера или добавить новые данные.
PUT: Заменить все текущие представления ресурса данными запроса. Используется для создания или обновления ресурса на сервере.
DELETE: Удалить указанный ресурс с сервера.
PATCH: Изменить часть ресурса на сервере. Используется для частичного обновления ресурса.
HEAD: Получить заголовки, которые будут отправлены при GET-запросе на указанный ресурс. Этот метод полезен, когда клиенту нужны только заголовки, а не фактическое содержимое.
OPTIONS: Получить информацию о возможностях сервера относительно ресурса или сервера в целом. Это может включать доступные методы, поддерживаемые заголовки и другую метаинформацию.
TRACE: Используется для тестирования соединения между клиентом и сервером. Когда сервер получает запрос TRACE, он возвращает весь запрос обратно клиенту, что позволяет клиенту увидеть, как запрос проходит через промежуточные узлы.
CONNECT: Используется для установки виртуального соединения с сервером, обеспечивая прозрачное шифрование SSL через промежуточный узел.
Веб-протокол HTTP (Hypertext Transfer Protocol) определяет различные методы запросов, которые клиенты могут отправлять серверу для выполнения определенных операций. Некоторые из наиболее распространенных HTTP-методов:
GET: Получить данные с сервера. Этот метод используется для запроса содержимого указанного ресурса.
POST: Отправить данные на сервер для обработки. Обычно используется для отправки данных формы или для выполнения какой-то операции на сервере, которая может изменить состояние сервера или добавить новые данные.
PUT: Заменить все текущие представления ресурса данными запроса. Используется для создания или обновления ресурса на сервере.
DELETE: Удалить указанный ресурс с сервера.
PATCH: Изменить часть ресурса на сервере. Используется для частичного обновления ресурса.
HEAD: Получить заголовки, которые будут отправлены при GET-запросе на указанный ресурс. Этот метод полезен, когда клиенту нужны только заголовки, а не фактическое содержимое.
OPTIONS: Получить информацию о возможностях сервера относительно ресурса или сервера в целом. Это может включать доступные методы, поддерживаемые заголовки и другую метаинформацию.
TRACE: Используется для тестирования соединения между клиентом и сервером. Когда сервер получает запрос TRACE, он возвращает весь запрос обратно клиенту, что позволяет клиенту увидеть, как запрос проходит через промежуточные узлы.
CONNECT: Используется для установки виртуального соединения с сервером, обеспечивая прозрачное шифрование SSL через промежуточный узел.
👍4
Как использовать компонент Symfony Console для создания пользовательской команды?
Чтобы создать пользовательскую команду в компоненте Symfony's Console, вам сначала нужно создать новый PHP-класс, который расширяет класс
После создания команды зарегистрируйте ее как сервис, пометив console.command в файле конфигурации сервисов. Теперь вы можете запускать команду из консоли, используя ее имя, заданное в
Чтобы создать пользовательскую команду в компоненте 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
На открытом уроке 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. Определите хэш коммита, который вы хотите влить:
Найдите нужный коммит и скопируйте его хэш.
2. Выполните команду
Если вам нужно влить несколько коммитов, вы можете указать диапазон:
Или перечислить несколько хэшей:
После выполнения
Дополнительные моменты:
Если возникнут конфликты при выполнении
Если вы передумали в процессе выполнения cherry-pick, вы можете отменить операцию с помощью:
Чтобы влить коммит в текущую ветку, используется команда 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