⊗ppPmSDRSP 446 of 447 menu

PHP 엔진 라우트에서 여러 개의 매개변수

이제 우리 웹사이트에 카테고리와 해당 카테고리에 속하는 페이지들이 있다고 가정해 보겠습니다. 카테고리 테이블을 만들어 봅시다:

categories
id slug name
1 first-category name1
2 second-category name2

그리고 페이지 테이블을 만듭니다:

pages
id slug title content category_id
1 my-first-page title1 <div> content1 </div> 1
2 my-second-page title2 <div> content2 </div> 1
3 my-third-page title3 <div> content3 </div> 2

우리 사이트에서는 서로 다른 카테고리의 페이지 슬러그가 일치하는 것을 허용합니다. 이는 URL에서 먼저 카테고리 슬러그를, 그 다음 페이지 슬러그를 다음과 같은 패턴으로 지정해야 한다는 의미입니다: /page/:category/:page, 여기서 콜론 뒤에는 변하는 매개변수 위치가 명시됩니다.

우리 사이트의 라우트를 작성해 봅시다:

<?php $route = '^/page/(?<catSlug>[a-z0-9_-]+)/(?<pageSlug>[a-z0-9_-]+) ; if (preg_match("#$route#", $url, $params)) { $page = include 'view/page/show.php'; } $route = '^/page/(?<catSlug>[a-z0-9_-]+) ; if (preg_match("#$route#", $url, $params)) { $page = include 'view/page/category.php'; } $route = '^/ ; if (preg_match("#$route#", $url, $params)) { $page = include 'view/page/all.php'; } ?>

첫 번째 라우트 핸들러에서는 요청된 페이지를 표시할 것입니다:

<?php $catSlug = $params['catSlug']; $pageSlug = $params['pageSlug']; $query = "SELECT pages.title, pages.content FROM pages LEFT JOIN category ON category.id=pages.category_id WHERE pages.slug='$pageSlug' AND category.slug='$catSlug'"; $res = mysqli_query($link, $query) or die(mysqli_error($link)); $page = mysqli_fetch_assoc($res); return $page; ?>

두 번째 라우트 핸들러에서는 지정된 카테고리의 페이지 목록을 표시할 것입니다:

<?php $catSlug = $params['catSlug']; $query = "SELECT pages.slug, pages.title FROM pages LEFT JOIN category ON category.id=pages.category_id WHERE category.slug='$catSlug'"; $res = mysqli_query($link, $query) or die(mysqli_error($link)); for ($data = []; $row = mysqli_fetch_assoc($res); $data[] = $row); $content = ''; foreach ($data as $page) { $content .= ' <div> <a href="/page/' . $catSlug . '/' . $page['slug'] . '">' . $page['title'] . '</a> </div> '; } $page = [ 'title' => $catSlug . ' 카테고리의 모든 페이지 목록', 'content' => $content ]; return $page; ?>

여러분에게 도시와 국가가 있는 웹사이트가 있다고 가정해 보겠습니다. 주소 /에서는 모든 국가 목록을, 주소 /:country에서는 매개변수에 지정된 국가의 도시 목록을, 그리고 주소 /:country/:city에서는 지정된 도시의 설명을 출력합니다.

한국어
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақКыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
우리는 웹사이트 운영, 분석 및 개인화를 위해 쿠키를 사용합니다. 데이터 처리는 개인정보 처리방침에 따라 이루어집니다.
모두 수락 설정 거부