Движок на база на податоци во PHP
Ајде сега да направиме двигател за веб-сајт, во кој содржината на страниците ќе се чува не во датотеки, туку во база на податоци. Нека во нашата база на податоци имаме ваква табела:
| id | title | content |
|---|---|---|
| 1 | title1 | <div> content1 </div> |
| 2 | title2 | <div> content2 </div> |
| 3 | title3 | <div> content3 </div> |
Нека сакаме да ги добиваме нашите страници по
URL-адреси од видот /page/1, каде што бројот ќе
го претставува id на страницата
која сакаме да ја добиеме.
Да почнеме со имплементација. За почеток во одделна датотека да направиме поврзување со базата на податоци и да ја поврземе таа датотека со нашата:
<?php
$link = require 'connect.php';
?>
Да го добиеме побараниот URL:
<?php
$url = $_SERVER['REQUEST_URI'];
?>
Со помош на регуларен израз да го поделиме URL-от на делови:
<?php
preg_match('#/page/(\d+)#', $url, $match);
?>
Да го запишеме id од "карман" во променлива:
<?php
$id = $match[1];
?>
Да извршиме барање до базата на податоци, по id
да ја добиеме побараната страница:
<?php
$query = "SELECT * FROM pages WHERE id=$id";
$res = mysqli_query($link, $query) or die(mysqli_error($link));
$page = mysqli_fetch_assoc($res);
?>
Да ја добиеме датотеката со шаблон:
<?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";
$res = mysqli_query($link, $query) or die(mysqli_error($link));
$page = mysqli_fetch_assoc($res);
$layout = file_get_contents('layout.php');
$layout = str_replace('{{ title }}', $page['title'], $layout);
$layout = str_replace('{{ content }}', $page['content'], $layout);
echo $layout;
?>
Имплементирајте го опишаниот двигател. Проверете ја неговата работа.