Один год с Symfony
Бесплатно!
With Membership
$7.99
Рекомендуемая цена

Один год с Symfony

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

О книге

Книгу "Один год с Symfony" написал разработчик из Голландии - Matthias Noback (http://php-and-symfony.matthiasnoback.nl/). Да, она про Symfony 2 (на текущий момент еще и довольно ранних версий), но она описывает и более общие принципы разработки нежели просто версию одного фреймворка - такие как "тонкие" контроллеры, слабая связность компонентов приложения, повторное использование кода, безопасность и т.д.

Книга в английском варианте доступна бесплатно на сайте leanpub - https://leanpub.com/a-year-with-symfony).

Если вы разрабатываете код на PHP (не обязательно на Symfony) - вам точно стоит прочитать эту книгу!

О авторах

Dmitry Bykadorov
Dmitry Bykadorov

In IT since end of 2001. Experienced in project management, quality assurance, web development.

Developing web-apps with PHP/Symfony, Python/Django/Flask, ASP.Net MVC/.Net Core, JavaScript/TypeScript/NestJs/ Angular 2+ MySQL/PosgreSQL/Oracle etc.

Matthias Noback
Matthias Noback

Matthias Noback has been building web applications since 2003. He is the author of Principles of Package Design and Object Design Style Guide and Advanced Web Application Architecture. He is a regular blogger, public speaker and trainer.

Оглавление

  • От переводчика
  • Предисловие
  • Введение
    • Благодарности
    • Кому предназначена эта книга
    • Соглашения
    • Обзор содержания книги
  • I От запроса до ответа
    • HttpKernelInterface
      • Загрузка ядра
        • Бандлы и расширения контейнера
        • Создание сервисного контейнера
      • От Kernel до HttpKernel
    • События, приводящие к ответу
      • Ранний ответ
        • Слушатели kernel.request, о которых вам нужно знать
      • Определение контроллера для запуска
      • Возможность замены контроллера
        • Примечательные слушатели события kernel.controller
      • Сбор аргументов для выполнения контроллера
      • Выполнение контроллера
      • Вход в слой представления (view)
        • Примечательные слушатели события kernel.view
      • Фильтрация ответа
        • Примечательные слушатели события kernel.response
    • Обработка исключений
      • Примечательные слушатели события kernel.exception
    • Подзапросы
      • Когда используются подзапросы?
  • II Приёмы внедрения зависимостей
    • Что такое бандл (bundle)
    • Приёмы создания сервисов
      • Обязательные зависимости
        • Обязательные параметры конструктора
          • Абстрактные определения для дополнительных аргументов
        • Вызов обязательных set-методов (setters)
          • Вызов методов в абстрактных сервисах
      • Необязательные (опциональные) зависимости
        • Необязательные аргументы конструктора
        • Необязательные вызовы set-методов
      • Коллекции сервисов
        • Вызов нескольких методов
        • Лучшее из двух миров
        • Метки сервисов (tags)
        • Вызов одного метода
        • Замена аргумента конструктора
        • Передаём ID сервисов вместо референсов
      • Делегирование создания
        • Не очень полезно…
        • Иногда всё-таки полезно…
      • Создание сервисов вручную
        • Определение
        • Аргументы
        • Таги
        • Алиасы (псевдонимы)
      • Класс Configuration
      • Динамическое добавление тагов
      • Используем паттерн Стратегия для загрузки сервисов
      • Загрузка и конфигурирование дополнительных сервисов
        • Подчищаем класс конфигурации
      • Конфигурируем сервис, который будем использовать
      • Полностью динамическое определение сервисов
    • Приёмы создания параметров
      • Файл parameters.yml
      • Определение и загрузка параметров
        • Параметры для имени класса
        • Сборка значений параметров вручную
      • Определяем параметры в расширениях контейнера
      • Переопределение параметров при помощи компилятора (compiler pass)
  • III Структура проекта
    • Организация слоёв приложения
      • Тонкие контроллеры
      • Обработчики форм
      • Доменные менеджеры
      • События
        • События уровня хранения (persistence)
    • Состояния и контекст
      • Контекст безопасности
      • Запрос
        • Избегаем зависимостей от текущего запроса
          • Используем слушатель (event listener)
          • Предоставлять объект запроса во время выполнения
          • Использование только нужных значений
  • IV Соглашения по конфигурированию
    • Настройка конфигурации приложения
      • Локальные конфигурационные файлы
        • Храните parameters.yml
        • Добавьте default_parameters.yml
    • Соглашения по конфигурированию
      • Маршрутизатор
        • Правила именования маршрутов
      • Сервисы
      • Метаданные Doctrine
  • V Безопасность
    • Введение
      • Symfony и безопасность
      • Цели: предотвращение и ограничение
        • Минимизация урона
        • Оценка мер по обеспечению безопасности
        • Перед тем как мы начнём…
    • Аутентификация и сессии
      • Инвалидация сессии
        • Угон сесии
        • Долгоиграющие сессии
    • Дизайн контроллеров
      • Защита действий в контроллерах
      • Размещение контроллеров за файрволлом
    • Валидация входных данных
      • Безопасные формы
        • HTML5-валидация
        • Ограничения валидатора
        • Формы без сущности
      • Валидация значений из запроса
        • Атрибуты запроса
          • Параметры маршрута
        • Query (GET) и request (POST) параметры
          • Используем ParamFetcher
      • Очистка HTML
        • Автоматизация очистки
    • Экранирование вывода
      • Twig
        • Контекст экранирования
        • Экранирование вывода функций
        • Экранирование аргументов функций
        • Опасности raw фильтра
    • Быть скрытным
      • Маскируйте ошибки аутентификации
      • Предотвращайте отображение исключений
      • Настройте страницы ошибок
      • Не сообщайте ничего определённого о конфиденциальных данных
  • VI Используем аннотации
    • Введение
    • Аннотация - это простой Объект-Значение (Value Object)
      • Добавляем аттрибуты к вашим аннотациям
        • Передача атрибутов через конструктор
        • Заполнение публичных свойств указанными атрибутами
        • Валидация при помощи @Attributes
        • Валидация при помощи аннотаций @var и @Required
      • Ограничения на использование аннотации
    • Когда стоит использовать аннотации
      • Загрузка конфигураций
      • Контроль процесса выполнения приложения
    • Используем аннотации в вашем Symfony-приложении
      • Реагируем на атрибуты запроса (Request): аннотация @Referrer
      • Предотвращаем выполнение контроллера: аннотация @RequiresCredits
      • Модифицируем ответ: аннотация @DownloadAs
    • Проектирование для повторого использования
    • Заключение
  • VII Быть Symfony разработчиком
    • Повторно используемый код должен иметь слабую связность
      • Разделяйте код копании от кода продукта
      • Разделяйте код на “библиотечный” и “бандловый”
      • Уменьшайте связность с фреймворком
        • Слушатели событий (listeners) вместо подписчиков (subscribers)
        • Аргументы конструктора вместо получения параметров из контейнера
        • Аргументы конструктора вместо получения сервисов из контейнера
        • О производительности
        • Контроллеры, не зависящие от фреймворка
        • Тонкие команды
        • Окружение
    • Повторно используемый код должен быть легко переносимым
      • Управление зависимостями и контроль версий
        • Репозитории пакетов
      • Жесткая привязка к хранилищу (базе данных)
        • Сущности с автоматическим сопоставлением (auto-mapped)
        • Модели, не привязанные к хранилищу
        • Менеджеры объектов
      • Жесткая привязка к файловой системе
        • Использование файловой системы
    • Повторно используемый код должен быть открыт для расширения
      • Настраиваемое поведение
      • Все должно быть заменяемым
        • Используйте интерфейсы
        • Используйте конфигурацию бандла для замены сервисов
      • Добавляйте точки расширения
        • Метки (таги) сервисов
        • События
    • Повторно используемый код должен быть лёгок в использовании
      • Добавьте документацию
      • Создавайте полезные исключения
        • Используйте специальные классы исключений
        • Указывайте детальные и понятные сообщения
    • Повторно используемый код должен быть надёжным
      • Добавляйте достаточное количество тестов
        • Тестируйте классы расширения и конфигурации вашего бандла
  • Заключение
    • Заключение от переводчика

Безусловная 100% гарантия счастья без риска от Leanpub

В течение 60 дней с момента покупки вы можете получить 100% возврат средств на любую покупку в Leanpub всего в два клика. Мы обрабатываем заявки на возврат средств вручную, так что этот процесс может занять несколько дней. Смотрите полные условия.

Earn $8 on a $10 Purchase, and $16 on a $20 Purchase

We pay 80% royalties on purchases of $7.99 or more, and 80% royalties minus a 50 cent flat fee on purchases between $0.99 and $7.98. You earn $8 on a $10 sale, and $16 on a $20 sale. So, if we sell 5000 non-refunded copies of your book for $20, you'll earn $80,000.

(Yes, some authors have already earned much more than that on Leanpub.)

In fact, authors have earnedover $13 millionwriting, publishing and selling on Leanpub.

Learn more about writing on Leanpub

Free Updates. DRM Free.

If you buy a Leanpub book, you get free updates for as long as the author updates the book! Many authors use Leanpub to publish their books in-progress, while they are writing them. All readers get free updates, regardless of when they bought the book or how much they paid (including free).

Most Leanpub books are available in PDF (for computers), EPUB (for phones and tablets) and MOBI (for Kindle). The formats that a book includes are shown at the top right corner of this page.

Finally, Leanpub books don't have any DRM copy-protection nonsense, so you can easily read them on any supported device.

Learn more about Leanpub's ebook formats and where to read them

Пишите и публикуйте на Leanpub

Авторы и издатели используют Leanpub для публикации замечательных ещё незаконченных и уже завершенных книг, как эта. Вы можете использовать Leanpub для написания, публикации и продажи своей книги! Leanpub - мощная платформа для серьезных авторов, сочетающая простой, элегантный письменный и издательский процесс с магазином, ориентированным на продажу продвигаемых электронных книг. Leanpub - волшебная пишущая машинка для авторов: просто пишите в текстовом виде и опубликуйте свою книгу, просто нажимая кнопку. Это действительно проще простого.

Узнать подробнее о написании на Leanpub