Давайте теперь сделаем движок сайта, в котором контент страниц будет хранится не в файлах, а в базе данных. Пусть у нас в базе данных есть вот такая таблица:
id | title | content |
---|---|---|
1 | title1 | <div> content1 </div> |
2 | title2 | <div> content2 </div> |
3 | title3 | <div> content3 </div> |
Пусть мы хотим получать наши страницы по
урлам вида /page/1
, где число будет
представлять собой id
той страницы,
которую мы хотим получить.
Приступим к реализации. Для начала в отдельном файле сделаем подключение к базе данных и подключим этот файл к нашему:
<?php
$link = require 'connect.php';
?>
Получим запрошенный URL:
<?php
$url = $_SERVER['REQUEST_URI'];
?>
С помощью регулярного выражения разделим урл на части:
<?php
preg_match('#/page/(\d+)#', $url, $match);
?>
Запишем id
из кармана в переменную:
<?php
$id = $match[1];
?>
Выполним запрос к базе данных, по id
получив запрошенную страницу:
<?php
$query = "SELECT * FROM pages WHERE id=$id";
$result = mysqli_query($link, $query) or die(mysqli_error($link));
$page = mysqli_fetch_assoc($result);
?>
Получим файл шаблона:
<?php
$layout = file_get_contents('layout.php');
?>
В файле шаблона выполним вставку тайтла и контента:
<?php
$layout = str_replace('{{ title }}', $page['title'], $layout);
$layout = str_replace('{{ content }}', $page['content'], $layout);
?>
Отправим собранную страницу сайта в браузер:
<?php
echo $layout;
?>
Соберем все вместе и получим следующий код:
<?php
require 'connect.php';
$url = $_SERVER['REQUEST_URI'];
preg_match('#/page/(\d+)#', $url, $match);
$id = $match[1];
$query = "SELECT * FROM pages WHERE id=$id";
$result = mysqli_query($link, $query) or die(mysqli_error($link));
$page = mysqli_fetch_assoc($result);
$layout = file_get_contents('layout.php');
$layout = str_replace('{{ title }}', $page['title'], $layout);
$layout = str_replace('{{ content }}', $page['content'], $layout);
echo $layout;
?>
Реализуйте описанный движок. Проверьте его работу.