⊗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
আমরা সাইট পরিচালনা, বিশ্লেষণ এবং ব্যক্তিগতকরণের জন্য কুকি ব্যবহার করি। ডেটা প্রক্রিয়াকরণ গোপনীয়তা নীতি অনুযায়ী করা হয়।
সব গ্রহণ করুন কনফিগার করুন প্রত্যাখ্যান করুন