⊗ppPmSDDb 442 of 447 menu

Pogon na bazi podatkov v PHP

Poglejmo si, kako narediti spletni pogon, v katerem bo vsebina strani shranjena ne v datotekah, ampak v podatkovni bazi. Predpostavimo, da imamo v podatkovni bazi naslednjo tabelo:

pages
id title content
1 title1 <div> content1 </div>
2 title2 <div> content2 </div>
3 title3 <div> content3 </div>

Predpostavimo, da želimo pridobiti naše strani z URL-ji oblike /page/1, kjer bo številka predstavljala id strani, ki jo želimo pridobiti.

Začnimo z implementacijo. Najprej v ločeni datoteki naredimo povezavo na podatkovno bazo in to datoteko povežimo z našo:

<?php $link = require 'connect.php'; ?>

Pridobimo zahtevani URL:

<?php $url = $_SERVER['REQUEST_URI']; ?>

Z uporabo regularnega izraza razdelimo URL na dele:

<?php preg_match('#/page/(\d+)#', $url, $match); ?>

Zapišimo id iz ujemanja (capture group) v spremenljivko:

<?php $id = $match[1]; ?>

Izvedimo poizvedbo na podatkovno bazo, da po id pridobimo zahtevano stran:

<?php $query = "SELECT * FROM pages WHERE id=$id"; $res = mysqli_query($link, $query) or die(mysqli_error($link)); $page = mysqli_fetch_assoc($res); ?>

Pridobimo datoteko predloge (template):

<?php $layout = file_get_contents('layout.php'); ?>

V datoteki predloge izvedimo vstavljanje naslova in vsebine:

<?php $layout = str_replace('{{ title }}', $page['title'], $layout); $layout = str_replace('{{ content }}', $page['content'], $layout); ?>

Pošljemo sestavljeno spletno stran v brskalnik:

<?php echo $layout; ?>

Vse skupaj sestavimo in dobimo naslednjo kodo:

<?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; ?>

Implementirajte opisani pogon. Preverite njegovo delovanje.

Slovenščina
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
Za delovanje spletnega mesta, analitiko in personalizacijo uporabljamo piškotke. Obdelava podatkov poteka v skladu s Politiko zasebnosti.
sprejmi vse nastavi zavrni