CakePHP с нуля: маленькое приложение. Часть 3 из 10
В предыдущем уроке мы рассмотрели базовый принцип функционирования рабочей среды CakePHP.
Построим какое-нибудь рабочее приложение. Это будет маленькое приложение с одной таблицей, которое мы будем использовать в следующих уроках и расширим до вполне функционального проекта. В конечном итоге мы построим приложение для представления данных о вакансиях с регистрацией, входом в систему, добавлением вакансии, принятием вакансии и так далее.
Нам понадобится соединение с базой данных. В первом уроке было описано, как его установить.
В данном уроке мы построим архитектуру MVC для таблицы категорий. Для лучшего представления CakePHP модель, контроллер и виды будут создаваться в уроке вручную. Да, есть другой способ. И он будет представлен в конце урока.
Создаем таблицу в базе данных:
CREATE TABLE `categories` ( `id` INTEGER(11) NOT NULL AUTO_INCREMENT, `name` VARCHAR(255) NOT NULL, PRIMARY KEY (`id`) ) ENGINE=MyISAM
Для использования философии MVC создадим модель для данной таблицы. Модели CakePHP располагаются в папке /app/models. Создаем файл category.php в папке /app/models и копируем туда следующий код. Обратите внимание на название класса, файла и таблицы. Они выбираются исходя из соглашения об именах (для имени таблицы используется множественное число) и должны соответствовать друг другу для того, чтобы в дальнейшем код было легко обслуживать.
<?php class Category extends AppModel { var $name = 'Category'; } ?>
Пока это все, что нужно для модели. Соглашение о именовании предполагает, что для имени класса и файла будет использоваться единственное число. В коде просто расширяем класс CakePHP AppModel и объявляется переменная $name, которая будет использоваться контроллером для доступа к функциям модели.
CakePHP хранит контроллеры в папке /app/controllers. Создаем файл с именем categories_controller.php в папке /app/controllers и копируем в в него код:
<?php class CategoriesController extends AppController { var $name = 'Categories'; function index() { $this->set('categories', $this->Category->find('all')); } } ?>
Код для контроллера несколько длиннее. Мы расширяем класс AppController и объявляем переменную $name. Также мы добавили функцию index. Функции контроллера называются action (действия).
Рассмотрим действия более подробно. Определяя функцию index() в нашем классе CategoriesController, мы даем пользователю доступ к адресу www.example.com/categories/index.
Рассмотрим строку с this в функции index():
$this->set('categories', $this->Category->find('all'));
С помощью одной строки кода мы выбираем все категории из таблицы и массив результатов в переменную categories. Данная переменная будет доступна в виде.
Файлы видов CakePHP хранятся в папке /app/views в подпапке с именем соответствующего контроллера (нам нужно создать папку с именем categories в нашем случае). Создаем файл index.ctp в папке /app/views/categories. Ctp файл - это файл шаблона CakePHP. Копируем в него код:
<!-- File: /app/views/categories/index.ctp --> <h1>Категории</h1> <table> <tr> <th>Id</th> <th>Название</th> </tr> <?php foreach ($categories as $category): ?> <tr> <td><?php echo $category['Category']['id']; ?></td> <td> <?php echo $html->link($category['Category']['name'], array('controller' => 'categories', 'action' => 'view', $category['Category']['id'])); ?> </td> </tr> <?php endforeach; ?> </table>
Как вы видите, index.ctp представляет собой смешанный файл с HTML и PHP кодом. Мы добавили все категории в переменную categories, поэтому можно использовать ее в цикле foreach. Здесь просто записываются данные в таблицу HTML. Для проверки того,что получилось нужно перейти на адрес URL установки CakePHP и добавить к нему /categories (например, http://localhost/cake/categories). Вы увидите данные в таблице.
Для генерации ссылки используется объект $html. Этот момент будет объяснен позже. Данный код генерирует ссылку на /categories/view/category_id . В нашем примере она не используется, но может представлять интерес при разработке кода MVC для таблицы статей.
Теперь изменим наш файл categories_controller.php:
class CategoriesController extends AppController { var $name = 'Categories'; function index() { $this->set('categories', $this->Category->find('all')); } function add() { if (!empty($this->data)) { if ($this->Category->save($this->data)) { $this->Session->setFlash('Ваша категория сохранена.'); $this->redirect(array('action' => 'index')); } } } }
Мы добавили функцию add(). Данная функция сохраняет данные в таблице categories. Выполняется проверка наличия значения в переменной. Данная переменная используется для хранения данных переданных из формы. Затем функция сохраняет данные, выводит сообщение и перенаправляет логику приложения обратно к функции index.
Создаем вид для нашего функционала (имя файла указано в первой строке):
<!-- File: /app/views/categories/add.ctp --> <h1>Добавить категорию</h1> <?php echo $form->create('Category'); echo $form->input('name'); echo $form->end('Сохранить'); ?>
Мы используем функционал CakePHP для создания формы. Если открыть данный вид с помощью браузера, использовав адрес действия (например, http://localhost/cake/categories/add ). То вы увидите готовую к работе форму. Если посмотреть на сгенерированный код, то вы увидидте, что CakePHP автоматически трансформировал вид в правильную форму.
Если функция create() будет вызвана без параметра, то это подразумевает, что вы строите форму, которая будет передавать данные текущему контроллеру действия add() (или edit()) через POST.
Метод $form->input() используется для создания элемента формы для поля ввода. Первый параметр сообщает, какому он полю соответствует. Второй параметр позволяет задавать широкий диапазон опций, например, количество строк для текстового поля. Метод input() выводит различные элементы формы в зависимости от заданных поле модели.
Метод $form->end() генерирует кнопку отправки формы и завершает форму. Если задана строка в качестве первого параметра, то выводится кнопка с соответствующим именем перед закрывающим тегом формы.
Теперь изменим вид /app/views/categories/index.ctp view для включения ссылки "Добавить категорию", чтобы иметь доступ к нашим новым функциям. Сразу после
<h1>Категория</h1>
добавляем:
<?php echo $html->link('Добавить категорию',array('controller' => 'categories', 'action' => 'add')); ?>
В следующем уроке мы добавим проверку данных, редактирование и удаление.
CakePHP имеет автоматический генератор кода MVC в соответствии со схемой базы данных! Но о нем речь пойдет в других уроках.
Источник: http://feedproxy.google.com/~r/ruseller/CdHX/~3/TogxlUVZE3M/lessons.php
Дайджест новых статей по интернет-маркетингу на ваш email
Новые статьи и публикации
- 2024-03-13 » Стратегии SEO на 2024 год
- 2024-03-13 » Как использовать анимацию с помощью JavaScript-библиотеки GSAP
- 2024-03-13 » Использование GSAP 3 для веб-анимации
- 2024-03-13 » Cогласование топографической съёмки с эксплуатирующими организациями
- 2024-02-19 » Теряются лиды? Как настроить сквозную аналитику
- 2024-02-17 » Мерч и IT: на что обратить внимание в 2024 году
- 2024-02-16 » Копируем с RSync: основные примеры синхронизации файлов
- 2024-02-15 » Лучшие noCode AI платформы для создания диалоговых ботов
- 2024-02-14 » Факторы ранжирования Google 2024 — исследование Semrush
- 2024-02-12 » Перенос сайта на другой хостинг
- 2024-02-05 » В России сформирован реестр хостинг-провайдеров
- 2024-02-04 » Использование SSH для подключения к удаленному серверу Ubuntu
- 2024-02-03 » Подключаемся к серверу за NAT при помощи туннеля SSH. Простая и понятная инструкция
- 2024-02-02 » Настройка CI/CD для Gitlab-репозитория: схемы и гайд по шагам
- 2024-02-01 » GitLab CI Pipeline. Запуск сценария через SSH на удаленном сервере
- 2024-01-29 » Introduction to GitLab’s CI/CD for Continuous Deployments
- 2024-01-26 » Настройка GitLab CI/CD
- 2024-01-25 » Установка shell gitlab runner
- 2024-01-25 » Установка и регистрация gitlab-runner в docker контейнере
- 2024-01-25 » Переменные Gitlab-Ci
- 2024-01-25 » Настройка CI/CD в GitLab для синхронизации проекта с веб-серверами
- 2024-01-25 » Копирование файлов scp
- 2024-01-21 » Бездепозитные бонусы от казино: обзор условий и правил использования
- 2024-01-18 » Современная обработка ошибок в PHP
- 2024-01-18 » Пример шаблона проектирования MVC в PHP
- 2024-01-18 » Мифический человеко-DevOps
- 2023-12-28 » Google подвел итоги 2023 года в поиске
- 2023-12-28 » 5 ошибок отдела продаж, из-за которых вы теряете клиентов
- 2023-12-28 » Американский суд признал монополию Google на рынках дистрибуции Android-приложений
- 2023-12-28 » Хостинг-провайдер GoDaddy перестанет оказывать услуги пользователям из России
Большинство людей, стремящихся к цели, способны скорее сделать одно большое усилие, чем упорно идти избранной дорогой; из-за лени и непостоянства они часто утрачивают плоды лучших своих начинаний и дают обогнать себя тем, кто отправился в путь позднее, чем они, и шел медленней, но зато безостановочно Лабрюйер Жан де (1645-1696) - французский писатель, мастер афористической публицистики |
Мы создаем сайты, которые работают! Профессионально обслуживаем и продвигаем их , а также по всей России и ближнему зарубежью с 2006 года!
Как мы работаем
Заявка
Позвоните или оставьте заявку на сайте.
Консультация
Обсуждаем что именно Вам нужно и помогаем определить как это лучше сделать!
Договор
Заключаем договор на оказание услуг, в котором прописаны условия и обязанности обеих сторон.
Выполнение работ
Непосредственно оказание требующихся услуг и работ по вашему заданию.
Поддержка
Сдача выполненых работ, последующие корректировки и поддержка при необходимости.