mata teras
Analisis permintaan/routing/penjadualan/kitaran tindak balas
Kelas permintaan yang merangkumi pelbagai URI dan parameter yang masuk dan mensimulasikan permintaan HTTP yang sangat mudah. Bagi keringkasan, ahli data tambahan seperti kaedah yang berkaitan dengan permintaan yang berkaitan telah sengaja dikecualikan. Jika anda mahu menambahkannya ke kelas, teruskan. Mempunyai pembalut permintaan HTTP yang nipis yang wujud secara bebas adalah baik, tetapi ia akan menjadi sia -sia tanpa gandingan dengan bahagian data dan tingkah laku yang sama yang menyerupai tindak balas HTTP yang tipikal. Mari Betulkan dan Bina Komponen Tambahan ini:
<code>class Request { public function __construct($uri, $params) { $this->uri = $uri; $this->params = $params; } public function getUri() { return $this->uri; } public function setParam($key, $value) { $this->params[$key] = $value; return $this; } public function getParam($key) { if (!isset($this->params[$key])) { throw new \InvalidArgumentException("The request parameter with key '$key' is invalid."); } return $this->params[$key]; } public function getParams() { return $this->params; } }</code>
Kelas tindak balas tidak diragukan lagi lebih aktif daripada permintaan rakan kongsi. Ia bertindak sebagai bekas asas yang membolehkan anda menyusun tajuk HTTP di Will dan dapat menghantarnya kepada pelanggan. Oleh kerana kelas-kelas ini menjalankan operasi mereka secara bebas, sudah tiba masanya untuk mula membina bahagian seterusnya pengawal hadapan. Dalam pelaksanaan biasa, proses penghalaan/penghantaran kebanyakannya dikemas dalam pendekatan yang sama, yang terus terang tidak terlalu buruk sama sekali. Walau bagaimanapun, dalam kes ini, lebih baik untuk memecahkan proses ini dan mewakilkannya ke kelas yang berbeza. Dengan cara ini, perkara akan lebih seimbang dari segi tanggungjawab yang sama. Berikut adalah kumpulan kelas yang membuat modul penghalaan dijalankan:
<code>class Response { public function __construct($version) { $this->version = $version; } public function getVersion() { return $this->version; } public function addHeader($header) { $this->headers[] = $header; return $this; } public function addHeaders(array $headers) { foreach ($headers as $header) { $this->addHeader($header); } return $this; } public function getHeaders() { return $this->headers; } public function send() { if (!headers_sent()) { foreach($this->headers as $header) { header("$this->version $header", true); } } } }</code>
seperti yang diharapkan, terdapat banyak pilihan ketika melaksanakan mekanisme penghalaan berfungsi. Sekurang -kurangnya pada pendapat saya, kaedah di atas adalah praktikal dan langsung. Ia mentakrifkan kelas laluan berasingan yang mengikat laluan ke pengawal operasi yang diberikan, dan penghala mudah yang tanggungjawabnya terhad untuk memeriksa sama ada laluan yang disimpan sepadan dengan URI yang berkaitan dengan objek permintaan tertentu. Untuk akhirnya menyelesaikan masalah ini, kita perlu menyediakan penjadual cepat yang boleh digunakan bersebelahan dengan kelas sebelumnya. Ini adalah bagaimana kelas berikut:
<code>class Route { public function __construct($path, $controllerClass) { $this->path = $path; $this->controllerClass = $controllerClass; } public function match(RequestInterface $request) { return $this->path === $request->getUri(); } public function createController() { return new $this->controllerClass; } } class Router { public function __construct($routes) { $this->addRoutes($routes); } public function addRoute(RouteInterface $route) { $this->routes[] = $route; return $this; } public function addRoutes(array $routes) { foreach ($routes as $route) { $this->addRoute($route); } return $this; } public function getRoutes() { return $this->routes; } public function route(RequestInterface $request, ResponseInterface $response) { foreach ($this->routes as $route) { if ($route->match($request)) { return $route; } } $response->addHeader("404 Page Not Found")->send(); throw new \OutOfRangeException("No route matched the given URI."); } }</code>
Imbas pengirim dan anda akan melihat dua perkara. Pertama, ia tidak membawa negeri. Kedua, secara tersirat mengandaikan bahawa setiap pengawal operasi akan berjalan di bawah permukaan kaedah pelaksanaan (). Ini boleh refactored kepada corak yang lebih fleksibel jika anda mahu (perkara pertama yang masuk ke dalam fikiran adalah untuk mengubahsuai pelaksanaan kelas laluan), tetapi untuk kesederhanaan, saya akan mengekalkan penjadual tidak berubah. Setakat ini, anda mungkin tertanya-tanya bagaimana untuk meletakkan pengawal front-end yang dapat menggabungkan semua kelas sebelumnya bersama-sama. Jangan risau, seterusnya!
<code>class Dispatcher { public function dispatch($route, $request, $response) $controller = $route->createController(); $controller->execute($request, $response); } }</code>
(disebabkan oleh batasan ruang, kandungan berikutnya akan dipotong. Sila berikan kandungan yang lain dan saya akan terus melengkapkan pseudo-asal.)
Atas ialah kandungan terperinci Pengenalan kepada Corak Pengawal Depan, Bahagian 2. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!