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-এ
নির্দিষ্ট শহরের বিবরণ প্রদর্শিত হোক।