php url 调度

Jun 23, 2016 pm 02:34 PM

1, 支持非rewrite即:
http://localhost/index.php/blog/view/5456-asdf.html
也可以被正确解析。。
-----------------------------------
2,增加:绝对地址生成 只要 
rurl('myFirstRouter', array('id' => '33', 'name' => 'thename'), true);
最后多加一个true,默认为false即相对地址。
生成绝对地址如:网站根目录/fleaphp/test/blog/view/33-thename.html

修改自ZendFramework的Router_Regexp类。
花了点时间整理的,水平有限,希望有高人能完善一下。

定义一个路由跟定义DSN一样的方法:

return array( 'routers' =>array(   'myFirstRouter' => array(    'blog/view(?:/(\d+)-(.+))\.html',    array(     'id'   => '1',     'controller'  => 'default',     'action'  => 'index'    ),    array(     1 => 'id',     2 => 'name'    ),    'blog/view/%d-%s.html'   ),   'mySecondRouter' => array(    'blog(?:/(\d+)-(.+))\.html',    array(     'id'   => '1',     'controller'  => 'default',     'action'  => 'index'    ),    array(     1 => 'id',     2 => 'name'    ),    'blog/%d-%s.html'   ),   'myThirdRouter' => array(    '([a-z0-9]+)/([a-z0-9]+)',    array(),    array(     1 => 'controller',     2 => 'action'    ),    'blog/%d-%s.html'   )   ) );

复制代码 是一个二维数组,每一个值为一条路由规则。
其中第一项是正则表达式,第二项为:参数默认值(这里可以设置controller,action,及其它参数的默认值。)
第三项为:参数的对应关系,与第一项的正则表达里面匹配元素对应。
第四项用于生成链接时候使用的格式。如果没看明白,可以看ZF的Router一节。

先发改的My_Dispatcher_Regexp类的代码:

loadRouters();         if (! is_array($this->_routers)) return false;         if (!$this->_pathInfo) $this->getPathInfo();                  foreach (array_reverse($this->_routers) as $router) {          if (! is_array($router)) continue;          if ($router[0] == '' || !is_string($router[0])) continue;          $regexp = '#^' . $router[0]. '$#i';    if (! isset($router[1])) $router[1] = array();          if (! isset($router[2])) $router[2] = array();          if ($args = $this->match($regexp, $this->_pathInfo, $router[1], $router[2])) {           $this->_curRouter = $router;           $data['controller'] = $args['controller'];           $data['action'] = $args['action'];           $_GET = array_merge($_GET, $args);           break;          }         }         $this->_request = $data;     }     /**      * 载入路由数据信息      *      */     function loadRouters() {      static $routerLoaded;      if ($routerLoaded) return;      $routerLoaded = false;      $routerConfig = FLEA::getAppInf('routerConfig');         FLEA::loadAppInf($routerConfig);         $this->_routers = FLEA::getAppInf('routers');         $routerLoaded = true;     }     /**      * 根据服务器环境不同,取得RequestUri信息      *      * @return unknown      */     function getRequestUri() {      if ($this->_requestUri) return $this->_requestUri;         if (isset($_SERVER['HTTP_X_REWRITE_URL'])) { // check this first so IIS will catch             $requestUri = $_SERVER['HTTP_X_REWRITE_URL'];         } elseif (isset($_SERVER['REQUEST_URI'])) {             $requestUri = $_SERVER['REQUEST_URI'];         } elseif (isset($_SERVER['ORIG_PATH_INFO'])) { // IIS 5.0, PHP as CGI             $requestUri = $_SERVER['ORIG_PATH_INFO'];             if (!empty($_SERVER['QUERY_STRING'])) {                 $requestUri .= '?' . $_SERVER['QUERY_STRING'];             }         } else {          $requestUri = null;         }         $this->_requestUri = $requestUri;         return $requestUri;     }     function getBaseUrl() {      if ($this->_baseUrl) return $this->_baseUrl;         $filename = basename($_SERVER['SCRIPT_FILENAME']);         if (basename($_SERVER['SCRIPT_NAME']) === $filename) {             $baseUrl = $_SERVER['SCRIPT_NAME'];         } elseif (basename($_SERVER['PHP_SELF']) === $filename) {             $baseUrl = $_SERVER['PHP_SELF'];         } elseif (isset($_SERVER['ORIG_SCRIPT_NAME']) && basename($_SERVER['ORIG_SCRIPT_NAME']) === $filename) {             $baseUrl = $_SERVER['ORIG_SCRIPT_NAME']; // 1and1 shared hosting compatibility         } else {             // Backtrack up the script_filename to find the portion matching             // php_self             $path    = $_SERVER['PHP_SELF'];             $segs    = explode('/', trim($_SERVER['SCRIPT_FILENAME'], '/'));             $segs    = array_reverse($segs);             $index   = 0;             $last    = count($segs);             $baseUrl = '';             do {                 $seg     = $segs[$index];                 $baseUrl = '/' . $seg . $baseUrl;                 ++$index;             } while (($last > $index) && (false !== ($pos = strpos($path, $baseUrl))) && (0 != $pos));         }         // Does the baseUrl have anything in common with the request_uri?         $requestUri = $this->getRequestUri();         if (0 === strpos($requestUri, $baseUrl)) {             // full $baseUrl matches             $this->_baseUrl = $baseUrl;             return $this->_baseUrl;         }         if (0 === strpos($requestUri, dirname($baseUrl))) {             // directory portion of $baseUrl matches             $baseUrl = rtrim(dirname($baseUrl), '/');             $this->_baseUrl = $baseUrl;             return $this->_baseUrl;         }         if (!strpos($requestUri, basename($baseUrl))) {             // no match whatsoever; set it blank             $this->_baseUrl = '';             return $this->_baseUrl;         }         // If using mod_rewrite or ISAPI_Rewrite strip the script filename         // out of baseUrl. $pos !== 0 makes sure it is not matching a value         // from PATH_INFO or QUERY_STRING         if ((strlen($requestUri) >= strlen($baseUrl))             && ((false !== ($pos = strpos($requestUri, $baseUrl))) && ($pos !== 0)))         {             $baseUrl = substr($requestUri, 0, $pos + strlen($baseUrl));         }        $baseUrl = rtrim($baseUrl, '/');         $this->_baseUrl = $baseUrl;         return $this->_baseUrl;         }     function getPathInfo () {         $baseUrl = $this->getBaseUrl();         if (null === ($requestUri = $this->getRequestUri())) {             return null;         }         // Remove the query string from REQUEST_URI         if ($pos = strpos($requestUri, '?')) {             $requestUri = substr($requestUri, 0, $pos);         }         if ((null !== $baseUrl)             && (false === ($pathInfo = substr($requestUri, strlen($baseUrl)))))         {             // If substr() returns false then PATH_INFO is set to an empty string             $pathInfo = '';         } elseif (null === $baseUrl) {             $pathInfo = $requestUri;         }         $this->_pathInfo = $pathInfo;         return $pathInfo;     }          /**      * Matches a user submitted path with a previously defined route.      * Assigns and returns an array of defaults on a successful match.      *      * @param string Path used to match against this routing map      * @return array|false An array of assigned values or a false on a mismatch      */     function match($regex, $path, $defaults, $map)     {         $path = trim(urldecode($path), '/');         $res = preg_match($regex, $path, $values);         if ($res === 0) return false;         foreach ($values as $i => $value) {             if (!is_int($i) || $i === 0) {                 unset($values[$i]);             }         }         $values = $this->_getMappedValues($map, $values);         $defaults = $this->_getMappedValues($map, $defaults, false, true);         $return = $values + $defaults;         return $return;     }     /**      * Maps numerically indexed array values to it's associative mapped counterpart.      * Or vice versa. Uses user provided map array which consists of index => name      * parameter mapping. If map is not found, it returns original array.      *      * Method strips destination type of keys form source array. Ie. if source array is      * indexed numerically then every associative key will be stripped. Vice versa if reversed      * is set to true.      *      * @param array Indexed or associative array of values to map      * @param boolean False means translation of index to association. True means reverse.      * @param boolean Should wrong type of keys be preserved or stripped.      * @return array An array of mapped values      */     function _getMappedValues($map, $values, $reversed = false, $preserve = false)     {         if (count($map) == 0) {             return $values;         }         $return = array();         foreach ($values as $key => $value) {             if (is_int($key) && !$reversed) {                 if (array_key_exists($key, $map)) {                     $index = $map[$key];                 } elseif (false === ($index = array_search($key, $map))) {                     $index = $key;                 }                 $return[$index] = $values[$key];             } elseif ($reversed) {                 $index = (!is_int($key)) ? array_search($key, $map, true) : $key;                 if (false !== $index) {                     $return[$index] = $values[$key];                 }             } elseif ($preserve) {                 $return[$key] = $value;             }         }         return $return;     }     /**      * Assembles a URL path defined by this route      *      * @param array An array of name (or index) and value pairs used as parameters      * @return string Route path with user submitted parameters      */     function assemble($defaults, $map = array(), $reverse, $data = array())     {         if ($reverse === null) {             return '构建网址失败!路由参数错误!';            }              $data = $this->_getMappedValues($map, $data, true, false);         $data += $this->_getMappedValues($map, $defaults, true, false);         //$data += $this->_values;         ksort($data);         $return = @vsprintf($reverse, $data);         if ($return === false) {             return '构建网址失败!';           }         return $return;     }     /**      * 使用路由构建网址      */     function url($routerName, $urlOptions, $absolute) {      $this->loadRouters();      if (isset($this->_routers[$routerName])) $curRouter = $this->_routers[$routerName];      elseif (isset($this->_curRouter)) $curRouter = $this->_curRouter;   if (is_array($curRouter) && count($curRouter) == 4 && is_string($curRouter[3])) {    $defaults = $curRouter[1];    $map = $curRouter[2];    $reverse = $curRouter[3];   } else {    return '构建网址失败!路由参数错误!';   }      if (is_array($map) && is_string($reverse))       if (!$absolute) return $this->assemble($defaults, $map, $reverse, $urlOptions);       else {        if (!$this->_baseUrl) $this->getBaseUrl();        return $this->_baseUrl . '/' .$this->assemble($defaults, $map, $reverse, $urlOptions);       }     } }

复制代码 这里要说一个比较好的自定义类的命名规则及文件放置位置。
在FLEA下面建一个My的目录里面放自已的类。比如My_Dispatcher_Regexp放在:
My/Dispatcher/Regexp.php

同时为方便写一个生成网址助手:
My_Helper_Router
My/Helper/Router.php
代码如下:

url($routerName, $urlOptions, $absolute); }

复制代码 使用方法:
/* 修改默认的Dispatcher为自定义的Dispatcher类*/
FLEA::setAppInf('dispatcher','My_Dispatcher_Regexp');

/* 设置路由配置信息的文件位置*/
FLEA::setAppInf('routerConfig', './APP/config/router.php');

其它代码跟任何一个普通的例子一样。

controller里面代码如下:

复制代码

我们在view中用下面代码:

'33', 'name' => 'thename'));

复制代码 就可以看到$_GET得到正确的参数,
rurl也生成我们期望的网址:
blog/view/33-thename.html

绝对网址生成方法如下:

rurl('myFirstRouter', array('id' => '33', 'name' => 'thename'),true); //将生成如下的网址: /other/fleaphp/test/blog/view/33-thename.html 如果没有使用apache的mod_rewrite功能生成的网址如下: /fleaphp/test/index.php/blog/view/33-thename.html

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
2 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
Repo: Wie man Teamkollegen wiederbelebt
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Abenteuer: Wie man riesige Samen bekommt
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

11 beste PHP -URL -Shortener -Skripte (kostenlos und Premium) 11 beste PHP -URL -Shortener -Skripte (kostenlos und Premium) Mar 03, 2025 am 10:49 AM

Lange URLs, die oft mit Schlüsselwörtern und Tracking -Parametern überfüllt sind, können Besucher abschrecken. Ein URL -Verkürzungsskript bietet eine Lösung, die präzise Links erstellt, die ideal für soziale Medien und andere Plattformen sind. Diese Skripte sind für einzelne Websites a wertvoll

Einführung in die Instagram -API Einführung in die Instagram -API Mar 02, 2025 am 09:32 AM

Nach seiner hochkarätigen Akquisition durch Facebook im Jahr 2012 nahm Instagram zwei APIs für den Einsatz von Drittanbietern ein. Dies sind die Instagram -Graph -API und die Instagram Basic Display -API. Ein Entwickler, der eine App erstellt, die Informationen von a benötigt

Arbeiten mit Flash -Sitzungsdaten in Laravel Arbeiten mit Flash -Sitzungsdaten in Laravel Mar 12, 2025 pm 05:08 PM

Laravel vereinfacht die Behandlung von temporären Sitzungsdaten mithilfe seiner intuitiven Flash -Methoden. Dies ist perfekt zum Anzeigen von kurzen Nachrichten, Warnungen oder Benachrichtigungen in Ihrer Anwendung. Die Daten bestehen nur für die nachfolgende Anfrage standardmäßig: $ Anfrage-

Erstellen Sie eine React -App mit einem Laravel -Back -Ende: Teil 2, reagieren Erstellen Sie eine React -App mit einem Laravel -Back -Ende: Teil 2, reagieren Mar 04, 2025 am 09:33 AM

Dies ist der zweite und letzte Teil der Serie zum Aufbau einer Reaktionsanwendung mit einem Laravel-Back-End. Im ersten Teil der Serie haben wir eine erholsame API erstellt, die Laravel für eine grundlegende Produktlistenanwendung unter Verwendung von Laravel erstellt hat. In diesem Tutorial werden wir Dev sein

Vereinfachte HTTP -Reaktion verspottet in Laravel -Tests Vereinfachte HTTP -Reaktion verspottet in Laravel -Tests Mar 12, 2025 pm 05:09 PM

Laravel bietet eine kurze HTTP -Antwortsimulationssyntax und vereinfache HTTP -Interaktionstests. Dieser Ansatz reduziert die Code -Redundanz erheblich, während Ihre Testsimulation intuitiver wird. Die grundlegende Implementierung bietet eine Vielzahl von Verknüpfungen zum Antworttyp: Verwenden Sie Illuminate \ Support \ facades \ http; Http :: fake ([ 'Google.com' => 'Hallo Welt',, 'github.com' => ['foo' => 'bar'], 'Forge.laravel.com' =>

Curl in PHP: So verwenden Sie die PHP -Curl -Erweiterung in REST -APIs Curl in PHP: So verwenden Sie die PHP -Curl -Erweiterung in REST -APIs Mar 14, 2025 am 11:42 AM

Die PHP Client -URL -Erweiterung (CURL) ist ein leistungsstarkes Tool für Entwickler, das eine nahtlose Interaktion mit Remote -Servern und REST -APIs ermöglicht. Durch die Nutzung von Libcurl, einer angesehenen Bibliothek mit Multi-Protokoll-Dateien, erleichtert PHP Curl effiziente Execu

12 Beste PHP -Chat -Skripte auf Codecanyon 12 Beste PHP -Chat -Skripte auf Codecanyon Mar 13, 2025 pm 12:08 PM

Möchten Sie den dringlichsten Problemen Ihrer Kunden in Echtzeit und Sofortlösungen anbieten? Mit Live-Chat können Sie Echtzeitgespräche mit Kunden führen und ihre Probleme sofort lösen. Sie ermöglichen es Ihnen, Ihrem Brauch einen schnelleren Service zu bieten

Ankündigung von 2025 PHP Situation Survey Ankündigung von 2025 PHP Situation Survey Mar 03, 2025 pm 04:20 PM

Die 2025 PHP Landscape Survey untersucht die aktuellen PHP -Entwicklungstrends. Es untersucht Framework -Nutzung, Bereitstellungsmethoden und Herausforderungen, die darauf abzielen, Entwicklern und Unternehmen Einblicke zu geben. Die Umfrage erwartet das Wachstum der modernen PHP -Versio

See all articles