Строим свою CMS на PHP и MySQL. Часть 3
Этот урок связан с проектом Сторим свою CMS на PHP и MySQL
В предыдущих уроках серии мы подготовили базу данных и класс Articleдля ядра нашей CMS. Теперь приступим к созданию скриптов, управляющих серверной и клиентской частью приложения.
1. Клиентская часть
Сначала создадим файл index.php, который будет содержать скрипт клиентской части, то есть выводить страницы в браузере пользователя. Копируем ниже приведенный код и сохраняем файл в корневом каталоге нашей CMS cms.
<?php
require( "config.php" );
$action = isset( $_GET['action'] ) ? $_GET['action'] : "";
switch ( $action ) {
case 'archive':
archive();
break;
case 'viewArticle':
viewArticle();
break;
default:
homepage();
}
function archive() {
$results = array();
$data = Article::getList();
$results['articles'] = $data['results'];
$results['totalRows'] = $data['totalRows'];
$results['pageTitle'] = "Article Archive | Widget News";
require( TEMPLATE_PATH . "/archive.php" );
}
function viewArticle() {
if ( !isset($_GET["articleId"]) || !$_GET["articleId"] ) {
homepage();
return;
}
$results = array();
$results['article'] = Article::getById( (int)$_GET["articleId"] );
$results['pageTitle'] = $results['article']->title . " | Widget News";
require( TEMPLATE_PATH . "/viewArticle.php" );
}
function homepage() {
$results = array();
$data = Article::getList( HOMEPAGE_NUM_ARTICLES );
$results['articles'] = $data['results'];
$results['totalRows'] = $data['totalRows'];
$results['pageTitle'] = "Widget News";
require( TEMPLATE_PATH . "/homepage.php" );
}
?>
Разберем код скрипта подробно.
-
Включаем файл конфигурации
Первая строка кода включает файл
config.php, и все установки приложения становятся доступны в скрипте. Мы используем функциюrequire(), а неinclude(), так какrequire()генерирует ошибку в случае отсутствия подключаемого файла.Notice that we use (int) to cast the value of the articleID query parameter to an integer. This is a good security measure, as it prevents anything other than integers from being passed to our code.
-
Получаем параметр
actionСохраняем параметр
$_GET['action']в переменной$action, чтобы можно было использовать значение далее в скрипте. Но прежде проверяем наличие значения$_GET['action']с помощью функцииisset(). Если его нет, устанавливаем для переменной$actionпустую строку ("").Проверять значения, поставляемые пользователем ( такие как строки, значения из форм, куки), на наличие перед использованием - хорошая практика программирования. Так не только ограничивается количество дырок в системе безопасности, но и предотвращает вывод предупреждения "undefined index" при выполнении скрипта.
-
Определяем действие для выполнения
Блок
switchпроверяет параметрactionв URL для определения нужного действия (вывести архив, просмотреть статью). Если параметрactionотсутствует в URL, то скрипт выводит главную страницу. -
Данная функция выводит список всех статей в базе данных. Для этого используется методarchive()getList()классаArticle. Функция сохраняет результат и заголовок страницы в ассоциированном массиве$results, и шаблон может вывести его на странице. В завершении включается шаблон для вывода страницы. (Мы рассмотрим шаблоны в другом уроке нашей серии.) -
viewArticle()Данная функция выводит страницу одной статьи. Она получает ID статьи для вывода из параметра URL
articleId, затем вызывает метод классаArticlegetById()для получения объекта статьи, который сохраняется в массиве$resultsдля использования в шаблоне. (Если нет параметраarticleIdили статья не может быть найдена, то функция просто выводит главную страницу.)Обратите внимание, что мы используем преобразование типов
(int)для явного приведения параметра запросаarticleIdк целому типу. Такое действие предотвращает передачу отличных от чисел значений в наш код. -
homepage()Последняя функция
homepage()выводит главную страницу сайта, на которой содержится список из нескольких статей, количество которых указано в парметре конфигурацииHOMEPAGE_NUM_ARTICLES(по умолчанию 5 ). Функция очень похожа на функциюarchive()за исключением передачи параметраHOMEPAGE_NUM_ARTICLESметодуgetList()для ограничения количества возвращаемых статей.
2. Серверная часть
Скрипт серверной части несколько сложнее, чем index.php, так как в нем реализованы функции администрирования для нашей CMS. Хотя основная структура похожа на index.php.
Создаем файл admin.php в том же каталоге, что и файл index.php. И копируем в него код:
<?php
require( "config.php" );
session_start();
$action = isset( $_GET['action'] ) ? $_GET['action'] : "";
$username = isset( $_SESSION['username'] ) ? $_SESSION['username'] : "";
if ( $action != "login" && $action != "logout" && !$username ) {
login();
exit;
}
switch ( $action ) {
case 'login':
login();
break;
case 'logout':
logout();
break;
case 'newArticle':
newArticle();
break;
case 'editArticle':
editArticle();
break;
case 'deleteArticle':
deleteArticle();
break;
default:
listArticles();
}
function login() {
$results = array();
$results['pageTitle'] = "Admin Login | Widget News";
if ( isset( $_POST['login'] ) ) {
// Пользователь получает форму входа: попытка авторизировать пользователя
if ( $_POST['username'] == ADMIN_USERNAME && $_POST['password'] == ADMIN_PASSWORD ) {
// Вход прошел успешно: создаем сессию и перенаправляем на страницу администратора
$_SESSION['username'] = ADMIN_USERNAME;
header( "Location: admin.php" );
} else {
// Ошибка входа: выводим сообщение об ошибке для пользователя
$results['errorMessage'] = "Incorrect username or password. Please try again.";
require( TEMPLATE_PATH . "/admin/loginForm.php" );
}
} else {
// Пользователь еще не получил форму: выводим форму
require( TEMPLATE_PATH . "/admin/loginForm.php" );
}
}
function logout() {
unset( $_SESSION['username'] );
header( "Location: admin.php" );
}
function newArticle() {
$results = array();
$results['pageTitle'] = "New Article";
$results['formAction'] = "newArticle";
if ( isset( $_POST['saveChanges'] ) ) {
// Пользователь получает форму редактирования статьи: сохраняем новую статью
$article = new Article;
$article->storeFormValues( $_POST );
$article->insert();
header( "Location: admin.php?status=changesSaved" );
} elseif ( isset( $_POST['cancel'] ) ) {
// Пользователь сбросид результаты редактирования: возвращаемся к списку статей
header( "Location: admin.php" );
} else {
// Пользователь еще не получил форму редактирования: выводим форму
$results['article'] = new Article;
require( TEMPLATE_PATH . "/admin/editArticle.php" );
}
}
function editArticle() {
$results = array();
$results['pageTitle'] = "Edit Article";
$results['formAction'] = "editArticle";
if ( isset( $_POST['saveChanges'] ) ) {
// Пользователь получил форму редактирования статьи: сохраняем изменения
if ( !$article = Article::getById( (int)$_POST['articleId'] ) ) {
header( "Location: admin.php?error=articleNotFound" );
return;
}
$article->storeFormValues( $_POST );
$article->update();
header( "Location: admin.php?status=changesSaved" );
} elseif ( isset( $_POST['cancel'] ) ) {
// Пользователь отказался от результатов редактирования: возвращаемся к списку статей
header( "Location: admin.php" );
} else {
// Пользвоатель еще не получил форму редактирования: выводим форму
$results['article'] = Article::getById( (int)$_GET['articleId'] );
require( TEMPLATE_PATH . "/admin/editArticle.php" );
}
}
function deleteArticle() {
if ( !$article = Article::getById( (int)$_GET['articleId'] ) ) {
header( "Location: admin.php?error=articleNotFound" );
return;
}
$article->delete();
header( "Location: admin.php?status=articleDeleted" );
}
function listArticles() {
$results = array();
$data = Article::getList();
$results['articles'] = $data['results'];
$results['totalRows'] = $data['totalRows'];
$results['pageTitle'] = "All Articles";
if ( isset( $_GET['error'] ) ) {
if ( $_GET['error'] == "articleNotFound" ) $results['errorMessage'] = "Error: Article not found.";
}
if ( isset( $_GET['status'] ) ) {
if ( $_GET['status'] == "changesSaved" ) $results['statusMessage'] = "Your changes have been saved.";
if ( $_GET['status'] == "articleDeleted" ) $results['statusMessage'] = "Article deleted.";
}
require( TEMPLATE_PATH . "/admin/listArticles.php" );
}
?>
Рассмотрим интересные места нашего скрипта:
-
Старт сессии пользователя
В начале скрипта мы вызываем функцию
session_start(). Данная функция PHP запускает новую сессию пользователя, которая позволяет нам контролировать регистрацию пользователя в системе. Если сессия для пользователя уже имеется, то PHP автоматически возобновит ее и будет использовать.Так как для сессии требуется работа с куки, и куки пересылаются в браузер перед содержанием, то следует вызывать
session_start()в начале скрипта, до отправки любого содержания. -
Получаем параметр
actionи переменную сессииusernameЗатем мы сохраняем параметр
$_GET['action']в переменной$action, а переменную сессии$_SESSION['username']в$username, чтобы затем использовать данные значения в скрипте. Перед сохранение осуществляем проверку с помощью функцииisset(). Если значение не существует, устанавливаем в соответствующей переменной пустую строку (""). -
Проверяем, зарегистрирован ли пользователь
Нельзя позволять пользователю совершать какие-либо операции, пока он не зарегистрируется как администратор. Поэтому нужно проверить
$usernameна наличие в сессии значения для ключаusername, который будет использоваться для подтверждения регистрации пользователя. Если значение$usernameпустое, то показываем страницу регистрации и выходим немедленно. -
Определяем действие для выполнения
Блок
switchработает так же как и вindex.php: производится вызов соответствующей функции на основании значения параметра URLaction. По умолчанию выводится список статей. -
login()Функция вызывается, когда нужно произвести регистрацию пользователя в системе.
Если пользователь отправил форму регистрации (что проверяется по параметру формы
login), то функция сопоставляет введенные имя и пароль со значениями параметров конфигурацииADMIN_USERNAMEиADMIN_PASSWORD. Если они соответствуют, то мы устанавливаем ключ сессииusernameв значение имени администратора, а затем перенаправляем обратно скриптуadmin.php, который выводит список статей. Если пароль и имя пользователя неверные, то будет выведена форма регистрации с сообщением об ошибке.Если пользователь еще не отправил форму регистрации, то просто выводим ее.
-
logout()Данная функция вызывается, когда пользователь выходит из системы. Здесь просто удаляется ключ сессии
usernameи производится перенаправление обратно вadmin.php. -
newArticle()Данная функция позволяет пользователю создавать новую статью. Если пользователь уже отправил форму для новой статьи, то функция создает новый объект
Article, сохраняет данные формы в объекте с помощью вызова функцииstoreFormValues(), вставляет статью в базу данных с помощью функцииinsert()и перенаправляет обратно на список статей, выводя сообщение об успешном завершении операции.Если пользователь не отправил форму для новой статьи, то функция создает новый пустой объект
Articleбез значений, затем использует шаблонeditArticle.phpдля вывода формы редактирования статьи для только что созданного объекта. -
editArticle()Данная функция похожа на
newArticle(), за исключением того, что пользователю предоставляется возможность редактировать статью. Когда пользователь сохраняет изменения, функция получает существующую статью с помощьюgetById(), записывает новые значения в объектеArticle, затем сохраняет измененный объект с помощью функцииupdate(). (Если статья не найдена в базе данных, функция выведет сообщение об ошибке.)Когда выводится форма редактирования статьи, функция использует метод
getById()для загрузки текущих значений в поля формы.Скрипт использует один и тот же шаблон (
editArticle.php) и для создания новой статьи и для редактирования имеющейся. То есть нужно создавать только одну форму HTML. ПараметрformActionиспользуется для определения операции со статьей. -
deleteArticle()Когда пользователь удаляет статью, данная функция сначала получает ее (если статьи нет в базе данных, то выводится сообщение об ошибке), а затем вызывает метод
delete()для удаления данных из базы. После завершения операции функция перенаправляет пользователя на страницу со списком статей и выводит сообщение о удалении. -
listArticles()Последняя функция функция в скрипте
admin.phpвыводит список статей в CMS. Используется методgetList()классаArticleдля получения всех статей. Затем применяем шаблонlistArticles.phpдля вывода списка. Кроме того, функция проверяет параметры запроса URLerrorиstatus, чтобы вывести сообщения об ошибке и состоянии системы, если нужно.
В следующем уроке мы создадим шаблоны для клиентской и серверной части.
Источник: http://feedproxy.google.com/~r/ruseller/CdHX/~3/SCtg06laZZo/lessons.php
|
Этот урок связан с проектом Сторим свою CMS на PHP и MySQLВ предыдущих уроках серии мы подготовили базу данных и класс Articleдля ядра нашей CMS. Теперь приступим к созданию скриптов, управляющих |
РэдЛайн, создание сайта, заказать сайт, разработка сайтов, реклама в Интернете, продвижение, маркетинговые исследования, дизайн студия, веб дизайн, раскрутка сайта, создать сайт компании, сделать сайт, создание сайтов, изготовление сайта, обслуживание сайтов, изготовление сайтов, заказать интернет сайт, создать сайт, изготовить сайт, разработка сайта, web студия, создание веб сайта, поддержка сайта, сайт на заказ, сопровождение сайта, дизайн сайта, сайт под ключ, заказ сайта, реклама сайта, хостинг, регистрация доменов, хабаровск, краснодар, москва, комсомольск |
Дайджест новых статей по интернет-маркетингу на ваш email
Новые статьи и публикации
- 2025-12-02 » Когда ошибка молчит: как бессмысленные сообщения ломают пользовательский опыт
- 2025-12-02 » 9 лучших бесплатных фотостоков
- 2025-12-02 » UTM-метки: ключевой инструмент аналитики для маркетолога
- 2025-12-02 » ПромоСтраницы Яндекса: Что такое и для чего служит
- 2025-12-02 » Метатеги для сайта: исчерпывающее руководство по Title, Description, Canonical, Robots и другим тегам
- 2025-11-26 » Оценка эффективности контента: превращаем информационный балласт в рабочий актив
- 2025-11-26 » 10 причин высокого показателя отказов на сайте
- 2025-11-26 » Когда и зачем обновлять структуру сайта
- 2025-11-26 » Скрытые демотиваторы: как мелочи разрушают эффективность команды
- 2025-11-26 » Зачем запускать MVP и как сделать это грамотно?
- 2025-11-20 » Половина российских компаний сократит расходы на транспорт и маркетинг в 2026 году
- 2025-11-20 » Перенос сайта с большим количеством ссылок
- 2025-11-20 » Перелинковка сайта: Что такое и как ее использовать
- 2025-11-20 » Критерии выбора SEO-специалиста и подрядчика для продвижения сайта
- 2025-11-20 » Применение искусственного интеллекта в рекламных агентствах: комплексное исследование трендов 2025 года
- 2025-11-19 » Геозапросы по-новому: как покорить локальное SEO с помощью ИИ
- 2025-11-14 » Консалтинг: сущность и ключевые направления
- 2025-11-14 » Онлайн-формы: универсальный инструмент для сбора обратной связи
- 2025-11-14 » Факторы конверсии органического трафика
- 2025-11-14 » Планирование рекламного бюджета: самостоятельный подход
- 2025-11-14 » Авторизация на сайте: как выбрать решение для удержания клиентов и сохранения продаж
- 2025-11-13 » Эффективные методы стимулирования клиентов к оставлению положительных отзывов
- 2025-11-13 » Налоговая реформа — 2026: грядущие изменения для предпринимателей
- 2025-11-13 » Альтернативы мессенджерам: что выбрать вместо Telegram и WhatsApp
- 2025-11-13 » Маркировка рекламы для начинающих: полное руководство по требованиям ЕРИР
- 2025-11-13 » ИИ не отберет вашу работу — её займет специалист, владеющий искусственным интеллектом
- 2025-10-29 » Как оценить эффективность работы SEO-специалиста: практическое руководство для маркетологов и владельцев бизнеса
- 2025-10-29 » Киберспорт как маркетинговый инструмент: стратегии привлечения геймеров
- 2025-10-29 » Как говорить с аудиторией о сложном
- 2025-10-29 » Что такое доказательства с нулевым разглашением (ZKP) и их роль в блокчейне
Мудрость приносит следующие три плода: дар хорошо мыслить, хорошо говорить и хорошо поступать Демокрит - (около 460 до н.э.- около 360 до н.э.) - древнегреческий философ |
Мы создаем сайты, которые работают! Профессионально обслуживаем и продвигаем их , а также по всей России и ближнему зарубежью с 2006 года!
Как мы работаем
Заявка
Позвоните или оставьте заявку на сайте.
Консультация
Обсуждаем что именно Вам нужно и помогаем определить как это лучше сделать!
Договор
Заключаем договор на оказание услуг, в котором прописаны условия и обязанности обеих сторон.
Выполнение работ
Непосредственно оказание требующихся услуг и работ по вашему заданию.
Поддержка
Сдача выполненых работ, последующие корректировки и поддержка при необходимости.


Мы создаем практически любые сайты от продающих страниц до сложных, высоконагруженных и нестандартных веб приложений! Наши сайты это надежные маркетинговые инструменты для успеха Вашего бизнеса и увеличения вашей прибыли! Мы делаем красивые и максимально эффектные сайты по доступным ценам уже много лет!
Комплексный подход это не просто продвижение сайта, это целый комплекс мероприятий, который определяется целями и задачами поставленными перед сайтом и организацией, которая за этим стоит. Время однобоких методов в продвижении сайтов уже прошло, конкуренция слишком высока, чтобы была возможность расслабиться и получать \ удерживать клиентов из Интернета, просто сделав сайт и не занимаясь им...
Мы оказываем полный комплекс услуг по сопровождению сайта: информационному и техническому обслуживанию и развитию Интернет сайтов.
Контекстная реклама - это эффективный инструмент в интернет маркетинге, целью которого является увеличение продаж. Главный плюс контекстной рекламы заключается в том, что она работает избирательно.