首页 后端开发 php教程 php url 调度

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

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解锁Myrise中的所有内容
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

在Laravel中使用Flash会话数据 在Laravel中使用Flash会话数据 Mar 12, 2025 pm 05:08 PM

Laravel使用其直观的闪存方法简化了处理临时会话数据。这非常适合在您的应用程序中显示简短的消息,警报或通知。 默认情况下,数据仅针对后续请求: $请求 -

php中的卷曲:如何在REST API中使用PHP卷曲扩展 php中的卷曲:如何在REST API中使用PHP卷曲扩展 Mar 14, 2025 am 11:42 AM

PHP客户端URL(curl)扩展是开发人员的强大工具,可以与远程服务器和REST API无缝交互。通过利用Libcurl(备受尊敬的多协议文件传输库),PHP curl促进了有效的执行

简化的HTTP响应在Laravel测试中模拟了 简化的HTTP响应在Laravel测试中模拟了 Mar 12, 2025 pm 05:09 PM

Laravel 提供简洁的 HTTP 响应模拟语法,简化了 HTTP 交互测试。这种方法显着减少了代码冗余,同时使您的测试模拟更直观。 基本实现提供了多种响应类型快捷方式: use Illuminate\Support\Facades\Http; Http::fake([ 'google.com' => 'Hello World', 'github.com' => ['foo' => 'bar'], 'forge.laravel.com' =>

在Codecanyon上的12个最佳PHP聊天脚本 在Codecanyon上的12个最佳PHP聊天脚本 Mar 13, 2025 pm 12:08 PM

您是否想为客户最紧迫的问题提供实时的即时解决方案? 实时聊天使您可以与客户进行实时对话,并立即解决他们的问题。它允许您为您的自定义提供更快的服务

解释PHP中晚期静态结合的概念。 解释PHP中晚期静态结合的概念。 Mar 21, 2025 pm 01:33 PM

文章讨论了PHP 5.3中引入的PHP中的晚期静态结合(LSB),从而允许静态方法的运行时分辨率调用以获得更灵活的继承。 LSB的实用应用和潜在的触摸

自定义/扩展框架:如何添加自定义功能。 自定义/扩展框架:如何添加自定义功能。 Mar 28, 2025 pm 05:12 PM

本文讨论了将自定义功能添加到框架上,专注于理解体系结构,识别扩展点以及集成和调试的最佳实践。

如何用PHP的cURL库发送包含JSON数据的POST请求? 如何用PHP的cURL库发送包含JSON数据的POST请求? Apr 01, 2025 pm 03:12 PM

使用PHP的cURL库发送JSON数据在PHP开发中,经常需要与外部API进行交互,其中一种常见的方式是使用cURL库发送POST�...

See all articles