Веб-разработка на PHP

Теория: Персистентность

Некоторые сайты относятся к статическим. Это готовый набор HTML-страничек. Например, так сделаны наши руководства на https://guides.hexlet.io/ru/. Удобно, быстро и дешево. Статическим сайтам не нужно куда-то сохранять информацию, его данные хранятся прямо в HTML.

Для создания статических сайтов используют специальные генераторы сайтов, например, jekyllrb.

Остальным сайтам повезло меньше. Всё, что создается пользователем, нужно куда-то сохранять.

Самый простой способ сохранять — использовать файлы. Но это нерабочий способ. Блокировки файловой системы не позволят работать с файлом в конкурентной среде, когда с сайтом могут одновременно работать сотни тысяч пользователей.

Для постоянного (персистентного) хранения данных принято использовать специализированные программы — базы данных. Взаимодействие с ними строят двумя способами:

  • Работая напрямую через библиотеку, предназначенную для данной базы данных
  • Работая через ORM, которая в большинстве случаев прячет базу данных за горой абстракций
<?php

// Doctrine ORM

$user = new User();
$user->setName($newUsername);

$entityManager->persist($user);
$entityManager->flush();

Тема хранения данных требует определенной подготовки. Это сделано намеренно. Профессия построена так, чтобы мы как можно быстрее добрались до веба и научились с ним работать. Подключением базы мы займемся в конце курса. По этой причине в следующих уроках данные пользователя будут сохраняться в сессии (механизм работающий поверх Cookie) через предоставленную абстракцию:

<?php

# Хранилище объектов
$repo = new App\UserRepository();

// Сохранение
$repo->save($user);
// Ещё одно сохранение
$repo->save($user2);

// Извлечение по идентификатору
$repo->find($entity['id']); // $entity

// Извлечение всех сущностей
$repo->all(); // [$entity, $entity2]

Репозиторий отвечает за хранение конкретной сущности. Для каждой свой: пользователи — UserRepository, машины — CarRepository и так далее.

Все репозитории далее по курсу созданы специально для этого курса. Они не являются частью фреймворка Slim или ORM. Исходные файлы любого репозитория доступны в практике.

Рекомендуемые программы