PHP 엔진 라우트에서 여러 개의 매개변수
이제 우리 웹사이트에 카테고리와 해당 카테고리에 속하는 페이지들이 있다고 가정해 보겠습니다. 카테고리 테이블을 만들어 봅시다:
| id | slug | name |
|---|---|---|
| 1 | first-category | name1 |
| 2 | second-category | name2 |
그리고 페이지 테이블을 만듭니다:
| 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에서는
지정된 도시의 설명을 출력합니다.